-
Notifications
You must be signed in to change notification settings - Fork 71
/
Copy pathtest-inline.R
68 lines (59 loc) · 1.73 KB
/
test-inline.R
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
withr::local_envvar(CLI_NO_BUILTIN_THEME = "true")
withr::local_options(cli.theme = NULL, cli.user_theme = NULL)
start_app()
on.exit(stop_app(), add = TRUE)
test_that_cli(config = c("plain", "ansi"), "inline classes", {
classes <- c(
"emph", "strong", "code", "pkg", "fun", "arg", "key", "file", "path",
"email", "url", "var", "envvar", "cls")
do <- function(class) {
special_style <- structure(
list(
list(color = "cyan"),
list(before = "<<<"),
list(after =">>>")),
names = c(
paste0("span.", class),
paste0("span.", class),
paste0("span.", class)
)
)
cli_div(theme = special_style)
txt <- glue::glue("This is {.<class> it} really",
.open = "<", .close = ">")
cli_text(txt)
}
expect_snapshot(
invisible(lapply(classes, do))
)
})
test_that("{{ and }} can be used for comments", {
expect_snapshot(local({
cli_text("Escaping {{ works")
cli_text("Escaping }} works")
cli_text("Escaping {{ and }} works")
cli_text("Escaping {{{{ works")
cli_text("Escaping }}}} works")
cli_text("Escaping {{{{ and }} works")
cli_text("Escaping {{{{ and }}}} works")
cli_text("Escaping {{ and }}}} works")
}))
})
test_that("no glue substitution in expressions that evaluate to a string", {
expect_snapshot(local({
msg <- "Message with special characters like } { }} {{"
cli_text("{msg}")
cli_text("{.emph {msg}}")
}))
})
test_that("S3 class is used for styling", {
expect_snapshot(local({
cli_div(
theme = list(
div = list("class-map" = list("foo" = "bar")),
".bar" = list(before = "::"))
)
obj <- structure("yep", class = "foo")
cli_text("This is {obj}.")
}))
})