mirror of
https://github.com/slint-ui/slint.git
synced 2025-08-06 03:38:48 +00:00

* syntax_tests: allow to "bless" tests, and don't use a regexp
A regexp was used at the beginning because I thought we would want to
allow error to contains things that were not predictable or that would
often change. But this is not the case¹. It is better to actually test
for the full error message
¹ well actually it was the case for path, but there is another substitution to
`📂` for the manifest directory
* syntax_tests: Bless the tests
* syntax_tests: Manual adjust after bless
Because there used to be comments on the same line of the message which
bless don't support
* Fix error message with path on windows
- The debug implementation of path make double slash, that's not what
we want to show the user
- normalize paths to use `/` so the test passes
42 lines
1.9 KiB
Text
42 lines
1.9 KiB
Text
// Copyright © SixtyFPS GmbH <info@slint.dev>
|
|
// SPDX-License-Identifier: GPL-3.0-only OR LicenseRef-Slint-Royalty-free-2.0 OR LicenseRef-Slint-Software-3.0
|
|
|
|
Button1 := Rectangle {
|
|
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
|
|
property <bool> cond;
|
|
accessible-role: cond ? button : AccessibleRole.text;
|
|
// ^error{The `accessible-role` property must be a constant expression}
|
|
|
|
rr := Rectangle {
|
|
init => {
|
|
self.accessible-role = AccessibleRole.text;
|
|
// ^error{The property must be known at compile time and cannot be changed at runtime}
|
|
}
|
|
}
|
|
}
|
|
|
|
Button2 := Rectangle {
|
|
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
|
|
accessible-label: "the button";
|
|
// ^error{The `accessible-label` property can only be set in combination to `accessible-role`}
|
|
}
|
|
|
|
Button3 := Rectangle {
|
|
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
|
|
Rectangle {
|
|
accessible-role: text;
|
|
accessible-label: "the button";
|
|
}
|
|
}
|
|
|
|
export Test := Window {
|
|
// ^warning{':=' to declare a component is deprecated. The new syntax declare components with 'component MyComponent {'. Read the documentation for more info}
|
|
|
|
Button1 { }
|
|
Button1 { accessible-description: "ok"; } // ok because Button1 has a role
|
|
Button2 { accessible-role: none; }
|
|
Button2 { }
|
|
Button3 {}
|
|
Button3 { accessible-description: "error";}
|
|
// ^error{The `accessible-description` property can only be set in combination to `accessible-role`}
|
|
}
|