11个不稳定版本 (3个破坏性更新)
0.4.4 | 2024年5月15日 |
---|---|
0.4.3 | 2024年3月3日 |
0.4.1 | 2024年1月9日 |
0.3.3 | 2024年1月2日 |
0.1.0 | 2023年11月14日 |
#247 in 测试
每月66次下载
在datadog-formatting-layer中使用
39KB
452 行
Smoothy
以流畅和易读的方式编写断言。
特性
此crate深受AssertJ的启发
- 简单易读的语法
- 基于断言值的类型的断言
- 断言值使用类型转换特性以使断言更易读
示例
所有断言都通过在值上调用assert_that
来启动。
之后可以做出基于断言值类型的各种断言。
use smoothy::assert_that;
assert_that(42).equals(42);
use smoothy::assert_that;
assert_that(1u8).try_into_equals(1i8);
use smoothy::assert_that;
assert_that(String::from("Hello")).equals("Hello");
use smoothy::assert_that;
assert_that("Hello World").contains("Hello").and().contains("World");
use smoothy::assert_that;
let result: Result<u8, String> = Ok(42);
assert_that(result)
.is_ok()
.and_value()
.equals(42);
use smoothy::assert_that;
let result: Result<(), String> = Err(String::from("ups!"));
assert_that(result)
.is_err()
.and_error()
.to_string()
.equals("ups!");
use smoothy::assert_that;
let option: Option<()> = None;
assert_that(option).is_none();
use smoothy::assert_that;
let option: Option<u8> = Some(1);
assert_that(option)
.is_some()
.and_value()
.equals(1);
use smoothy::assert_that;
let iterable: Vec<String> = vec![];
assert_that(iterable).is_empty();
use smoothy::assert_that;
assert_that(vec![1, 2, 3]).is_not_empty();
use smoothy::assert_that;
assert_that([1, 2, 3]).first().is(1);
use smoothy::assert_that;
assert_that([1, 2, 3]).nth(1).is(2);
断言结构图
stateDiagram-v2
[*] --> BasicAsserter<Assertable> : assert_that
BasicAsserter<Assertable> --> Anything
state "Assertable is any type" as Anything {
[*] --> AssertionConnector<Assertable> : is
[*] --> AssertionConnector<Assertable> : is_not
[*] --> AssertionConnector<Assertable> : equals
[*] --> AssertionConnector<Assertable> : not_equals
[*] --> AssertionConnector<Assertable> : try_into_equals
[*] --> AssertionConnector<Assertable> : try_into_not_equqls
AssertionConnector<Assertable> --> [*] : and
}
BasicAsserter<Assertable> --> Result
state "Assertable is Result<Ok, Err>" as Result {
[*] --> OkAsserter<Ok> : is_ok
OkAsserter<Ok> --> BasicAsserter<Ok> : and_value
[*] --> ErrAsserter<Err> : is_err
ErrAsserter<Err> --> BasicAsserter<Err> : and_error
}
BasicAsserter<Assertable> --> Option
state "Assertable is Option<Some>" as Option {
[*] --> [*] : is_none
[*] --> SomeAsserter<Some> : is_some
SomeAsserter<Some> --> BasicAsserter<Some> : and_value
}
BasicAsserter<Assertable> --> ImplString
state "Assertable implements ToString" as ImplString {
[*] --> BasicAsserter<String> : to_string
}
BasicAsserter<Assertable> --> ImplAsRefStr
state "Assertable implements AsRef<str>" as ImplAsRefStr {
[*] --> AssertionConnector<AsRef<str>> : contains
[*] --> AssertionConnector<AsRef<str>> : is_matching
AssertionConnector<AsRef<str>> --> [*] : and
}
BasicAsserter<Assertable> --> ImplIntoIter
state "Assertable implements IntoIter<Item>" as ImplIntoIter {
[*] --> [*] : is_empty
[*] --> [*] : is_not_empty
[*] --> BasicAsserter<Item>: first
[*] --> BasicAsserter<Item>: second
[*] --> BasicAsserter<Item>: third
[*] --> BasicAsserter<Item>: nth
}
依赖
~2.4–3.5MB
~56K SLoC