mirror of
https://github.com/slint-ui/slint.git
synced 2025-10-21 15:52:19 +00:00

Base the commercial license on the Royalty-free license adding clauses pertaining to the fees.
88 lines
3.8 KiB
Text
88 lines
3.8 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
|
|
|
|
export component TestCase { }
|
|
|
|
/*
|
|
```cpp
|
|
auto handle = TestCase::create();
|
|
const TestCase &instance = *handle;
|
|
|
|
// Check time mocking without event delivery happening:
|
|
auto start_time = slint_testing::get_mocked_time();
|
|
slint_testing::mock_elapsed_time(512);
|
|
assert(slint_testing::get_mocked_time() == start_time + 512);
|
|
slint_testing::mock_elapsed_time(10333);
|
|
auto pre_event1_time = slint_testing::get_mocked_time();
|
|
assert_eq(pre_event1_time, start_time + 512 + 10333);
|
|
|
|
// Test that the first mouse event keeps time consistent
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
auto post_event1_time = slint_testing::get_mocked_time();
|
|
assert(post_event1_time >= pre_event1_time && post_event1_time < pre_event1_time + 100); // allow for a bit of time for event handling...
|
|
|
|
// Test that a second mouse event keeps time consistent
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
auto post_event2_time = slint_testing::get_mocked_time();
|
|
assert(post_event2_time >= post_event1_time && post_event2_time < post_event1_time + 100);
|
|
|
|
// Test that mocking works after mouse event delivery:
|
|
slint_testing::mock_elapsed_time(500000);
|
|
auto pre_event3_time = slint_testing::get_mocked_time();
|
|
assert(pre_event3_time == post_event2_time + 500000);
|
|
|
|
// Test that a new event does not break the mocked time again
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
auto post_event3_time = slint_testing::get_mocked_time();
|
|
assert(post_event3_time >= pre_event3_time && post_event3_time <= pre_event3_time + 100);
|
|
```
|
|
|
|
```rust
|
|
let instance = TestCase::new().unwrap();
|
|
|
|
// Check time mocking without event delivery happening:
|
|
let start_time = slint_testing::get_mocked_time();
|
|
slint_testing::mock_elapsed_time(512);
|
|
assert_eq!(slint_testing::get_mocked_time(), start_time + 512, "Mocked time is wrong");
|
|
slint_testing::mock_elapsed_time(10333);
|
|
let pre_event1_time = slint_testing::get_mocked_time();
|
|
assert_eq!(pre_event1_time, start_time + 512 + 10333);
|
|
|
|
// Test that the first mouse event keeps time consistent
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
let post_event1_time = slint_testing::get_mocked_time();
|
|
assert!(post_event1_time >= pre_event1_time && post_event1_time < pre_event1_time + 100); // allow for a bit of time for event handling...
|
|
|
|
// Test that a second mouse event keeps time consistent
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
let post_event2_time = slint_testing::get_mocked_time();
|
|
assert!(post_event2_time >= post_event1_time && post_event2_time < post_event1_time + 100);
|
|
|
|
// Test that mocking works after mouse event delivery:
|
|
slint_testing::mock_elapsed_time(500000);
|
|
let pre_event3_time = slint_testing::get_mocked_time();
|
|
assert_eq!(pre_event3_time, post_event2_time + 500000);
|
|
|
|
// Test that a new event does not break the mocked time again
|
|
slint_testing::send_mouse_click(&instance, 5., 5.);
|
|
let post_event3_time = slint_testing::get_mocked_time();
|
|
assert!(post_event3_time >= pre_event3_time && post_event3_time <= pre_event3_time + 100);
|
|
```
|
|
|
|
```js
|
|
var instance = new slint.TestCase({});
|
|
|
|
let start_time = slintlib.private_api.get_mocked_time();
|
|
slintlib.private_api.mock_elapsed_time(512);
|
|
assert(slintlib.private_api.get_mocked_time() == start_time + 512);
|
|
slintlib.private_api.mock_elapsed_time(122);
|
|
assert(slintlib.private_api.get_mocked_time() == start_time + 512 + 122);
|
|
slintlib.private_api.mock_elapsed_time(10333);
|
|
assert(slintlib.private_api.get_mocked_time() == start_time + 512 + 122 + 10333);
|
|
|
|
// FIXME: Sending a mouse event undoes the mock_elapsed_time calls on Node at this time!
|
|
// slintlib.private_api.send_mouse_click(instance, 5., 5.);
|
|
// assert(slintlib.private_api.get_mocked_time() == start_time + 512 + 122 + 10333);
|
|
```
|
|
|
|
*/
|