forked from animint/animint2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
test-renderer3-FunctionalPruning.R
61 lines (54 loc) · 1.87 KB
/
test-renderer3-FunctionalPruning.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
acontext("FunctionalPruning")
data(FunctionalPruning, package="animint2")
min.bug.viz <- list(
pruning=a_plot()+
a_geom_line(a_aes(mean, cost),
showSelected="minimization",
color="grey",
size=5,
data=FunctionalPruning$envelope)+
a_geom_line(a_aes(mean, cost, color=data.i.fac,
group=paste(piece.i, data.i)),
showSelected="minimization",
data=FunctionalPruning$cost.lines)+
a_geom_point(a_aes(min.cost.mean, min.cost,
color=data.i.fac),
showSelected="minimization",
size=5,
data=FunctionalPruning$minima),
data=a_plot()+
a_geom_tile(a_aes(timestep, total.segments,
fill=optimal.cost,
id=paste0("segs", total.segments, "time", timestep)),
clickSelects="minimization",
data=FunctionalPruning$grid),
first=list(minimization="2 segments up to data point 4")
)
info <- animint2HTML(min.bug.viz)
some.lines <- subset(FunctionalPruning$cost.lines, timestep==4 & n.segments==2)
with(some.lines, table(data.i, piece.i))
test_that("one line rendered for min envelope", {
path.list <- getNodeSet(
info$html,
'//g[@class="a_geom1_line_pruning"]//path')
expect_equal(length(path.list), 1)
})
test_that("four lines rendered for cost candidates", {
path.list <- getNodeSet(
info$html,
'//g[@class="a_geom2_line_pruning"]//path')
expect_equal(length(path.list), 4)
})
html <- clickHTML(id="segs1time4")
test_that("min envelope line disappears", {
path.list <- getNodeSet(
html,
'//g[@class="a_geom1_line_pruning"]//path')
expect_equal(length(path.list), 0)
})
test_that("cost candidates lines disappear", {
path.list <- getNodeSet(
html,
'//g[@class="a_geom2_line_pruning"]//path')
expect_equal(length(path.list), 0)
})