These raw log messages are meant to help Ambient developers figure out problems. You can ignore them.
{
"type": "executor_starts",
"name": "ambient-execute-plan",
"version": "0.13.1@52633e5",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 513275547
},
"log_source": "Plan"
}{
"type": "runnable_plan",
"steps": [
{
"action": "mkdir",
"pathname": "/ci"
},
{
"action": "mkdir",
"pathname": "/ci/artifacts"
},
{
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src"
},
{
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps"
},
{
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache"
},
{
"action": "shell",
"shell": "ln -sf /ci /workspace"
},
{
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'"
},
{
"action": "shell",
"shell": "git config --global user.email ambient@example.com"
},
{
"action": "cargo_fmt"
},
{
"action": "cargo_clippy"
},
{
"action": "shell",
"shell": "make OFFLINE=\"--offline\"\ncp -a doc/* /ci/artifacts/.\n\n# Clean up after tests and documentation building.\ngit reset --hard\ngit clean -fdx\ngit status --ignored\n"
},
{
"action": "custom",
"name": "dch",
"args": {
"debfullname": "Lars Wirzenius",
"debemail": "liw@liw.fi"
}
},
{
"action": "deb",
"packages": "."
},
{
"action": "shell",
"shell": "find /ci/artifacts\n"
},
{
"action": "tar_create",
"archive": "/dev/vde",
"directory": "/ci/cache"
},
{
"action": "tar_create",
"archive": "/dev/vdd",
"directory": "/ci/artifacts"
}
],
"executor_drive": "/dev/vdb",
"source_drive": "/dev/vdc",
"artifact_drive": "/dev/vdd",
"cache_drive": "/dev/vde",
"deps_drive": "/dev/vdf",
"workspace_dir": "/ci",
"source_dir": "/ci/src",
"deps_dir": "/ci/deps",
"cache_dir": "/ci/cache",
"artifacts_dir": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 516127710
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "mkdir",
"pathname": "/ci",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 536175236
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "mkdir",
"pathname": "/ci",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 543191921
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "mkdir",
"pathname": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 547191363
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "mkdir",
"pathname": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 550869959
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 553595293
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vdc",
"directory": "/ci/src",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 583094141
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps",
"timestamp": {
"secs_since_epoch": 1774034791,
"nanos_since_epoch": 586956289
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vdf",
"directory": "/ci/deps",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 930485454
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 930519534
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_extract",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 937021207
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "ln -sf /ci /workspace",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 937042537
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
108,
110,
32,
45,
115,
102,
32,
47,
99,
105,
32,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 937053684
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ ln -sf /ci /workspace\n",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 948821339
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "ln -sf /ci /workspace",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 951499684
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 953878488
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
103,
105,
116,
32,
99,
111,
110,
102,
105,
103,
32,
45,
45,
103,
108,
111,
98,
97,
108,
32,
117,
115,
101,
114,
46,
110,
97,
109,
101,
32,
39,
65,
109,
98,
105,
101,
110,
116,
32,
67,
73,
39,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 956532478
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ git config --global user.name 'Ambient CI'\n",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 966891193
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "git config --global user.name 'Ambient CI'",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 969758607
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "git config --global user.email ambient@example.com",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 972427300
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
103,
105,
116,
32,
99,
111,
110,
102,
105,
103,
32,
45,
45,
103,
108,
111,
98,
97,
108,
32,
117,
115,
101,
114,
46,
101,
109,
97,
105,
108,
32,
97,
109,
98,
105,
101,
110,
116,
64,
101,
120,
97,
109,
112,
108,
101,
46,
99,
111,
109,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 975197375
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "+ git config --global user.email ambient@example.com\n",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 983275066
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "git config --global user.email ambient@example.com",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 986257849
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "cargo_fmt",
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 989038492
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034792,
"nanos_since_epoch": 991050850
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "cargo 1.94.0 (85eff7c80 2026-01-15)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 46088547
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
99,
108,
105,
112,
112,
121
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 48834244
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "clippy 0.1.94 (4a4ef493e3 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 155572094
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
114,
117,
115,
116,
99
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 155613624
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "rustc 1.94.0 (4a4ef493e 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 202692207
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
102,
109,
116
]
},
{
"Unix": [
45,
45,
99,
104,
101,
99,
107
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 205461973
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 437034681
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "cargo_fmt",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 437069407
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "cargo_clippy",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 437074889
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 437083076
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "cargo 1.94.0 (85eff7c80 2026-01-15)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 480883266
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
99,
108,
105,
112,
112,
121
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 480922206
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "clippy 0.1.94 (4a4ef493e3 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 564289817
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
114,
117,
115,
116,
99
]
},
{
"Unix": [
45,
45,
118,
101,
114,
115,
105,
111,
110
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 567061743
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "rustc 1.94.0 (4a4ef493e 2026-03-02)\n",
"stderr": "",
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 608524307
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
99,
97,
114,
103,
111
]
},
{
"Unix": [
99,
108,
105,
112,
112,
121
]
},
{
"Unix": [
45,
45,
111,
102,
102,
108,
105,
110,
101
]
},
{
"Unix": [
45,
45,
108,
111,
99,
107,
101,
100
]
},
{
"Unix": [
45,
45,
119,
111,
114,
107,
115,
112,
97,
99,
101
]
},
{
"Unix": [
45,
45,
97,
108,
108,
45,
116,
97,
114,
103,
101,
116,
115
]
},
{
"Unix": [
45,
45,
110,
111,
45,
100,
101,
112,
115
]
},
{
"Unix": [
45,
45
]
},
{
"Unix": [
45,
45,
100,
101,
110,
121
]
},
{
"Unix": [
119,
97,
114,
110,
105,
110,
103,
115
]
}
],
"timestamp": {
"secs_since_epoch": 1774034793,
"nanos_since_epoch": 611265083
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "",
"stderr": " Compiling proc-macro2 v1.0.103\n Compiling quote v1.0.42\n Compiling unicode-ident v1.0.22\n Checking cfg-if v1.0.4\n Compiling zerocopy v0.8.31\n Compiling serde_core v1.0.228\n Checking memchr v2.7.6\n Compiling syn v2.0.111\n Compiling crossbeam-utils v0.8.21\n Compiling libc v0.2.178\n Compiling version_check v0.9.5\n Compiling ahash v0.8.12\n Checking once_cell v1.21.3\n Compiling serde v1.0.228\n Checking aho-corasick v1.1.4\n Checking regex-syntax v0.8.8\n Checking bitflags v2.10.0\n Compiling anyhow v1.0.100\n Compiling doc-comment v0.3.4\n Compiling serde_derive v1.0.228\n Compiling getrandom v0.3.4\n Compiling rustix v1.1.2\n Compiling same-file v1.0.6\n Compiling libm v0.2.15\n Compiling walkdir v2.5.0\n Checking itoa v1.0.15\n Compiling ucd-trie v0.1.7\n Compiling pest v2.8.4\n Compiling shlex v1.3.0\n Compiling thiserror v2.0.17\n Compiling find-msvc-tools v0.1.5\n Compiling serde_json v1.0.145\n Compiling cc v1.2.49\n Compiling pest_meta v2.8.4\n Compiling thiserror-impl v2.0.17\n Compiling pikchr v0.1.4\n Compiling pest_generator v2.8.4\n Compiling tracing-attributes v0.1.31\n Compiling pest_derive v2.8.4\n Compiling pulldown-cmark v0.13.0\n Checking linux-raw-sys v0.11.0\n Checking regex-automata v0.4.13\n Checking lazy_static v1.5.0\n Checking fastrand v2.3.0\n Compiling log v0.4.29\n Checking ryu v1.0.20\n Checking base64 v0.22.1\n Compiling encoding_rs v0.8.35\n Compiling num-conv v0.1.0\n Compiling arraydeque v0.5.1\n Compiling time-core v0.1.6\n Compiling time-macros v0.2.24\n Compiling crossbeam-epoch v0.9.18\n Checking tempfile v3.23.0\n Compiling hashbrown v0.14.5\n Compiling getrandom v0.2.16\n Checking regex v1.12.2\n Compiling subplot v0.14.0 (/ci/src)\n Compiling bstr v1.12.1\n Compiling unicode-width v0.2.2\n Compiling foldhash v0.1.5\n Compiling globset v0.4.18\n Compiling hashbrown v0.15.5\n Compiling rand_core v0.6.4\n Compiling hashlink v0.9.1\n Compiling crossbeam-deque v0.8.6\n Compiling serde_path_to_error v0.1.20\n Compiling ppv-lite86 v0.2.21\n Compiling culpa-macros v1.0.2\n Compiling cfg_aliases v0.2.1\n Compiling nix v0.29.0\n Compiling rand_chacha v0.3.1\n Compiling ignore v0.4.25\n Compiling yaml-rust2 v0.9.0\n Compiling hashlink v0.10.0\n Checking powerfmt v0.2.0\n Compiling smawk v0.3.2\n Compiling unicode-linebreak v0.1.5\n Compiling deunicode v1.6.2\n Compiling textwrap v0.16.2\n Compiling slug v0.1.6\n Checking deranged v0.5.5\n Compiling humansize v2.1.3\n Compiling yaml-rust2 v0.10.4\n Compiling marked-yaml v0.7.2\n Compiling globwalk v0.9.1\n Compiling rand v0.8.5\n Compiling getopts v0.2.24\n Compiling tracing-core v0.1.36\n Compiling pulldown-cmark-escape v0.11.0\n Compiling utf8-width v0.1.8\n Compiling unicode-segmentation v1.12.0\n Compiling pin-project-lite v0.2.16\n Compiling unicase v2.8.1\n Compiling percent-encoding v2.3.2\n Compiling tera v1.20.1\n Compiling tracing v0.1.44\n Compiling html-escape v0.2.13\n Checking time v0.3.44\n Compiling roadmap v0.7.0\n Compiling marked-yaml v0.8.0\n Checking culpa v1.0.2\n Checking cvt v0.1.2\n Compiling descape v3.0.0\n Compiling line-col v0.2.1\n Checking fs_at v0.2.1\n Checking normpath v1.5.0\n Compiling subplotlib v0.14.0 (/ci/src/subplotlib)\n Checking remove_dir_all v1.0.0\n Checking fs2 v0.4.3\n Checking filetime v0.2.26\n Checking shell-words v1.1.1\n Checking state v0.6.0\n Compiling subplotlib-derive v0.14.0 (/ci/src/subplotlib-derive)\n Checking utf8parse v0.2.2\n Checking anstyle-parse v0.2.7\n Checking anstyle-query v1.1.5\n Checking anstyle v1.0.13\n Checking is_terminal_polyfill v1.70.2\n Checking colorchoice v1.0.4\n Checking anstream v0.6.21\n Checking strsim v0.11.1\n Compiling heck v0.5.0\n Checking clap_lex v0.7.6\n Compiling clap_derive v4.5.49\n Checking clap_builder v4.5.53\n Checking clap v4.5.53\n Compiling git-testament-derive v0.2.1\n Checking tracing-log v0.2.0\n Checking sharded-slab v0.1.7\n Checking matchers v0.2.0\n Checking thread_local v1.1.9\n Checking nu-ansi-term v0.50.3\n Checking smallvec v1.15.1\n Checking tracing-subscriber v0.3.22\n Checking git-testament v0.2.6\n Checking subplot-bin v0.14.0 (/ci/src/bin)\n Checking subplot-seq-example v0.1.0 (/ci/src/examples/seq)\n Finished `dev` profile [unoptimized + debuginfo] target(s) in 42.32s\n",
"timestamp": {
"secs_since_epoch": 1774034836,
"nanos_since_epoch": 33776182
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "cargo_clippy",
"timestamp": {
"secs_since_epoch": 1774034836,
"nanos_since_epoch": 87122072
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "make OFFLINE=\"--offline\"\ncp -a doc/* /ci/artifacts/.\n\n# Clean up after tests and documentation building.\ngit reset --hard\ngit clean -fdx\ngit status --ignored\n",
"timestamp": {
"secs_since_epoch": 1774034836,
"nanos_since_epoch": 87301895
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
109,
97,
107,
101,
32,
79,
70,
70,
76,
73,
78,
69,
61,
34,
45,
45,
111,
102,
102,
108,
105,
110,
101,
34,
10,
99,
112,
32,
45,
97,
32,
100,
111,
99,
47,
42,
32,
47,
99,
105,
47,
97,
114,
116,
105,
102,
97,
99,
116,
115,
47,
46,
10,
10,
35,
32,
67,
108,
101,
97,
110,
32,
117,
112,
32,
97,
102,
116,
101,
114,
32,
116,
101,
115,
116,
115,
32,
97,
110,
100,
32,
100,
111,
99,
117,
109,
101,
110,
116,
97,
116,
105,
111,
110,
32,
98,
117,
105,
108,
100,
105,
110,
103,
46,
10,
103,
105,
116,
32,
114,
101,
115,
101,
116,
32,
45,
45,
104,
97,
114,
100,
10,
103,
105,
116,
32,
99,
108,
101,
97,
110,
32,
45,
102,
100,
120,
10,
103,
105,
116,
32,
115,
116,
97,
116,
117,
115,
32,
45,
45,
105,
103,
110,
111,
114,
101,
100,
10,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1774034836,
"nanos_since_epoch": 87314854
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "which cargo\n/root/.cargo/bin/cargo\nwhich dot\n/usr/bin/dot\nwhich plantuml\n/usr/bin/plantuml\nwhich python3\n/usr/bin/python3\nwhich rustc\n/root/.cargo/bin/rustc\nwhich rustfmt\n/root/.cargo/bin/rustfmt\nwhich tidy\n/usr/bin/tidy\nif which shellcheck; then shellcheck *.sh; fi\n/usr/bin/shellcheck\nif cargo clippy --version; then \\\n cargo clippy --locked --offline --workspace --all-targets -- -Dwarnings && \\\n\tcd examples/seq && cargo clippy --workspace --all-targets -- -Dwarnings; \\\nfi\nclippy 0.1.94 (4a4ef493e3 2026-03-02)\nrm -rf \"/ci/src/inst\"\ncargo install --target x86_64-unknown-linux-musl --locked --offline --path=bin --root=\"/ci/src/inst\" --debug\nmv \"/ci/src/inst\"/bin/* \"/ci/src/inst\"\nrm -rf \"/ci/src/inst\"/.crate* \"/ci/src/inst\"/bin\ncd share/python/template && python3 context_tests.py\ncd share/python/template && python3 encoding_tests.py\nenv SUBPLOT_DIR=\"/ci/src/inst\" cargo test --target x86_64-unknown-linux-musl --workspace -- \n\nrunning 108 tests\ntest bindings::test_binding::creates_new ... ok\ntest bindings::test_binding::does_not_match_with_wrong_kind ... ok\ntest bindings::test_binding::case_sensitive_mismatch ... ok\ntest bindings::test_binding::does_not_match_with_wrong_text ... ok\ntest bindings::test_binding::match_with_fixed_pattern ... ok\ntest bindings::test_binding::equal ... ok\ntest bindings::test_binding::not_equal ... ok\ntest bindings::test_bindings::add_from_yaml_notices_multiple_keywords ... ok\ntest bindings::test_bindings::adds_binding ... ok\ntest bindings::test_binding::match_with_regex ... ok\ntest bindings::test_bindings::does_not_find_match_for_unmatching_kind ... ok\ntest bindings::test_bindings::does_not_find_match_for_unmatching_pattern ... ok\ntest bindings::test_bindings::finds_match_for_fixed_string_pattern ... ok\ntest bindings::test_bindings::finds_match_for_regexp_pattern ... ok\ntest bindings::test_bindings::has_no_bindings_initially ... ok\ntest bindings::test_bindings::two_matching_bindings ... ok\ntest bindings::test_bindings::adds_from_yaml ... ok\ntest bindings::test_bindings::typemap_must_match_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::returns_boring_pattern_as_is ... ok\ntest bindings::test_regex_from_simple_pattern::returns_empty_string_as_is ... ok\ntest bindings::test_regex_from_simple_pattern::kindless_simple_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::returns_error_for_stray_closing_brace ... ok\ntest bindings::test_regex_from_simple_pattern::returns_error_for_stray_closing_brace_before_capture ... ok\ntest bindings::test_regex_from_simple_pattern::returns_error_for_stray_opening_brace ... ok\ntest bindings::test_regex_from_simple_pattern::returns_error_for_stray_opening_brace_before_capture ... ok\ntest bindings::test_regex_from_simple_pattern::returns_pattern_with_regexp_chars_escaped ... ok\ntest bindings::test_regex_from_simple_pattern::simple_int_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::simple_number_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::simple_text_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::simple_word_pattern ... ok\ntest bindings::test_regex_from_simple_pattern::typemap_and_pattern_kind_must_match ... ok\ntest bindings::test_regex_from_simple_pattern::typemap_checked_on_pattern_parse_and_default_agrees ... ok\ntest bindings::test_regex_from_simple_pattern::typemap_updated_on_pattern_parse_default ... ok\ntest bindings::test_regex_from_simple_pattern::typemap_updated_on_pattern_parse_explicit ... ok\ntest bindings::test_regex_from_simple_pattern::typemap_used_when_kind_not_present ... ok\ntest blockattr::test::empty_braces ... ok\ntest blockattr::test::empty_string ... ok\ntest blockattr::test::just_word ... ok\ntest blockattr::test::open_brace_without_close ... ok\ntest blockattr::test::parse_one_dotted_word ... ok\ntest blockattr::test::parse_one_id ... ok\ntest blockattr::test::parse_one_kv ... ok\ntest blockattr::test::parse_one_kv_with_double_quotes ... ok\ntest blockattr::test::parse_one_kv_with_single_quotes ... ok\ntest blockattr::test::parse_one_word ... ok\ntest blockattr::test::two_ids ... ok\ntest blockattr::test::two_words ... ok\ntest codegen::test::verify_commentsafe_filter ... ok\ntest codegen::test::verify_name_slugification ... ok\ntest html::test_tag::can_self_close ... ok\ntest html::test_tag::cannot_self_close ... ok\ntest matches::test::returns_text ... ok\ntest matches::test::returns_uncaptured ... ok\ntest matches::test_partial_steps::different_captured_texts_dont_match ... ok\ntest matches::test_partial_steps::different_uncaptured_texts_dont_match ... ok\ntest matches::test_partial_steps::differently_captured_texts_dont_match ... ok\ntest matches::test_partial_steps::differently_named_captured_texts_dont_match ... ok\ntest matches::test_partial_steps::identical_captured_texts_match ... ok\ntest matches::test_partial_steps::identical_uncaptured_texts_match ... ok\ntest md::test::finds_block_classes ... ok\ntest md::test::finds_embedded_files ... ok\ntest md::test::finds_images ... ok\ntest md::test::finds_no_blocks_in_empty_doc ... ok\ntest md::test::finds_no_classes_when_no_blocks_have_them ... ok\ntest md::test::finds_no_embedded_files_in_empty_doc ... ok\ntest md::test::finds_no_images_in_empty_doc ... ok\ntest md::test::finds_no_scenarios_in_empty_doc ... ok\ntest md::test::finds_scenarios ... ok\ntest md::test::loads_empty_doc ... ok\ntest md::test::parses_auto_as_auto ... ok\ntest md::test::parses_empty_as_error ... ok\ntest md::test::parses_garbage_as_error ... ok\ntest md::test::parses_no_as_no ... ok\ntest md::test::parses_no_auto_newline_as_auto ... ok\ntest md::test::parses_yes_as_yes ... ok\ntest md::test_extract::returns_error_if_scenario_has_no_title ... ok\ntest md::test_extract::returns_nothing_if_there_is_no_scenario ... ok\ntest md::test_extract::returns_parent_section_with_scenario_snippet ... ok\ntest md::test_extract::returns_scenario_if_there_is_one ... ok\ntest md::test_extract::skips_scenarioless_deeper_headings ... ok\ntest md::test_extract::skips_scenarioless_parent_heading ... ok\ntest md::test_extract::skips_scenarioless_section_in_favour_of_same_level ... ok\ntest metadata::test::full_meta ... ok\ntest scenarios::filtertest::exclude_slow ... ok\ntest scenarios::filtertest::exclude_unimportant_slow ... ok\ntest scenarios::filtertest::include_all ... ok\ntest scenarios::filtertest::include_fast ... ok\ntest scenarios::filtertest::include_none ... ok\ntest scenarios::test::adds_step ... ok\ntest scenarios::test::has_no_steps_initially ... ok\ntest scenarios::test::has_title ... ok\ntest steps::test::fails_to_parse_and ... ok\ntest steps::test::parses_and ... ok\ntest steps::test::parses_given ... ok\ntest steps::test::parses_given_with_extra_spaces ... ok\ntest steps::test::parses_then ... ok\ntest steps::test::parses_when ... ok\ntest steps::test_steps_parser::empty_string ... ok\ntest steps::test_steps_parser::preserve_nonascii_whitespace ... ok\ntest steps::test_steps_parser::simple ... ok\ntest steps::test_steps_parser::two_simple ... ok\ntest templatespec::test::new_from_yaml ... ok\ntest toc::test_numberer::numbering ... ok\ntest toc::test_slugs::short_and_simple ... ok\ntest toc::test_slugs::unique_for_identical_simple_headings ... ok\ntest toc::test_toc::iterate ... ok\ntest toc::test_toc::uses_given_slug ... ok\ntest bindings::test_regex_from_simple_pattern::simple_uint_pattern ... ok\n\ntest result: ok. 108 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.24s\n\n\nrunning 1 test\ntest bindings_microbenchmark ... ok\n\ntest result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 2.24s\n\n\nrunning 0 tests\n\ntest result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 4 tests\ntest more_than_one_number ... ok\ntest no_arguments ... ok\ntest not_a_number ... ok\ntest one_number ... ok\n\ntest result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 0 tests\n\ntest result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 7 tests\ntest create_on_disk_files_from_embedded_files ... ok\ntest directories ... ok\ntest file_and_directory_removal ... ok\ntest file_equality ... ok\ntest file_metadata ... ok\ntest file_modification_time ... ok\ntest file_contents ... ok\n\ntest result: ok. 7 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s\n\n\nrunning 21 tests\ntest check_stderr_doesn_t_contain_sub_string ... ok\ntest check_stderr_doesn_t_match_regular_expressions ... ok\ntest check_stderr_is_exactly_as_wanted ... ok\ntest check_stderr_is_not_exactly_something ... ok\ntest check_stderr_using_sub_string_search ... ok\ntest check_stderr_using_regular_expressions ... ok\ntest check_stdout_doesn_t_contain_sub_string ... ok\ntest check_stdout_is_exactly_as_wanted ... ok\ntest check_stdout_doesn_t_match_regular_expression ... ok\ntest check_stdout_is_not_exactly_something ... ok\ntest check_stdout_using_regular_expressions ... ok\ntest check_stdout_using_sub_string_search ... ok\ntest check_we_can_prepend_to__path ... ok\ntest execution_in_a_sub_directory_does_not_affect_home ... ok\ntest failed_execution ... ok\ntest failed_execution_in_a_sub_directory ... ok\ntest stdin_comes_from_a_named_file ... ok\ntest stdin_contains_exactly ... ok\ntest setting_and_clearing_of_environment_variables ... ok\ntest successful_execution_in_a_sub_directory ... ok\ntest successful_execution ... ok\n\ntest result: ok. 21 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.02s\n\n\nrunning 28 tests\ntest capture_using_regular_expressions ... ok\ntest all_the_keywords ... ok\ntest capture_using_simple_patterns ... ok\ntest cleanup_functions_get_called_on_failure__python_ ... ok\ntest code_generator_gives_an_error_if_input_document_lacks_title ... ok\ntest cleanup_functions_gets_called_on_success__python_ ... ok\ntest examples_are_not_files ... ok\ntest empty_lines_in_scenarios ... ok\ntest files_not_in_current_working_directory ... ok\ntest lowest_level_heading_is_name_of_scenario ... ok\ntest missing_functions_file ... ok\ntest misuse_of_continuation_keywords ... ok\ntest next_heading_at_higher_level_starts_new_scenario ... ok\ntest no_scenarios_means_codegen_fails ... ok\ntest no_template_means_you_can_docgen_but_not_codegen ... ok\ntest next_heading_at_same_level_starts_new_scenario ... ok\ntest recall_values_for_use_in_later_steps ... ok\ntest running_only_chosen_scenarios_with_python ... ok\ntest simple_patterns_with_regex_metacharacters__allowed_case ... ok\ntest simple_patterns_with_regex_metacharacters__forbidden_case ... ok\ntest set_environment_variables_in_generated_test_programs ... ok\ntest steps_which_do_not_case_sensitively_match_sensitive_bindings_do_not_work ... ok\ntest steps_which_do_not_match_bindings_do_not_work ... ok\ntest steps_which_match_more_than_one_binding_do_not_work ... ok\ntest smoke_test ... ok\ntest subheadings_don_t_start_new_scenario ... ok\ntest subplot_accepts_title_and_headings_with_inline_markup ... ok\ntest temporary_files_in_scenarios_in_python ... ok\n\ntest result: ok. 28 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.04s\n\n\nrunning 4 tests\ntest pikchr ... ok\ntest dot ... ok\ntest roadmap ... ok\ntest plantuml ... ok\n\ntest result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.08s\n\n\nrunning 28 tests\ntest bad__add_newline__value ... ok\ntest attempt_to_use_definition_list ... ok\ntest class_name_validation ... ok\ntest date_given_in_metadata ... ok\ntest date_given_on_command_line ... ok\ntest document_generator_gives_an_error_if_input_document_lacks_title ... ok\ntest dot ... ok\ntest css_urls ... ok\ntest embedded_css ... ok\ntest examples_may_be_unused ... ok\ntest extract_embedded_file ... ok\ntest fail_if_embedded_file_isn_t_used ... ok\ntest fail_if_two_filenames_only_differ_in_case ... ok\ntest empty_lines_in_scenarios ... ok\ntest indented_scenario_steps_are_not_allowed ... ok\ntest files_not_in_current_working_directory ... ok\ntest missing_bindings_file ... ok\ntest multiple_markdown_files ... ok\ntest no_date_anywhere ... ok\ntest no_template_means_you_can_docgen_but_not_codegen ... ok\ntest pikchr ... ok\ntest named_code_blocks_must_have_an_appropriate_class ... ok\ntest roadmap ... ok\ntest scenario_before_the_first_heading ... ok\ntest smoke_test ... ok\ntest subplot_accepts_title_and_headings_with_inline_markup ... ok\ntest title_markup ... ok\ntest plantuml ... ok\n\ntest result: ok. 28 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.81s\n\n\nrunning 1 test\ntest extract_embedded_files ... ok\n\ntest result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 5 tests\ntest duplicate_scenario_titles ... ok\ntest extracting_metadata_from_a_document ... ok\ntest list_embedded_files ... ok\ntest scenario_titles ... ok\ntest files_not_in_current_working_directory ... ok\n\ntest result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.21s\n\n\nrunning 64 tests\ntest attempt_to_use_definition_list ... ok\ntest bad__add_newline__value ... ok\ntest capture_using_regular_expressions ... ok\ntest all_the_keywords ... ok\ntest class_name_validation ... ok\ntest capture_using_simple_patterns ... ok\ntest cleanup_functions_get_called_on_failure__python_ ... ok\ntest code_generator_gives_an_error_if_input_document_lacks_title ... ok\ntest css_urls ... ok\ntest date_given_in_metadata ... ok\ntest cleanup_functions_gets_called_on_success__python_ ... ok\ntest date_given_on_command_line ... ok\ntest document_generator_gives_an_error_if_input_document_lacks_title ... ok\ntest dot ... ok\ntest duplicate_scenario_titles ... ok\ntest embedded_css ... ok\ntest examples_are_not_files ... ok\ntest examples_may_be_unused ... ok\ntest extract_embedded_file ... ok\ntest extract_embedded_file__automatically_add_missing_newline ... ok\ntest extract_embedded_file__by_default_add_missing_newline ... ok\ntest extract_embedded_file__by_default_do_not_add_a_second_newline ... ok\ntest extract_embedded_file__do_not_add_missing_newline ... ok\ntest extract_embedded_file__do_not_automatically_add_second_newline ... ok\ntest extract_embedded_file__explicitly_add_missing_newline ... ok\ntest extract_embedded_file__explicitly_add_second_newline ... ok\ntest extract_embedded_files ... ok\ntest extracting_metadata_from_a_document ... ok\ntest fail_if_embedded_file_isn_t_used ... ok\ntest fail_if_the_same_filename_is_used_twice ... ok\ntest fail_if_two_filenames_only_differ_in_case ... ok\ntest empty_lines_in_scenarios ... ok\ntest indented_scenario_steps_are_not_allowed ... ok\ntest list_embedded_files ... ok\ntest lowest_level_heading_is_name_of_scenario ... ok\ntest missing_bindings_file ... ok\ntest files_not_in_current_working_directory ... ok\ntest missing_functions_file ... ok\ntest misuse_of_continuation_keywords ... ok\ntest multiple_markdown_files ... ok\ntest named_code_blocks_must_have_an_appropriate_class ... ok\ntest next_heading_at_higher_level_starts_new_scenario ... ok\ntest no_date_anywhere ... ok\ntest no_scenarios_means_codegen_fails ... ok\ntest no_template_means_you_can_docgen_but_not_codegen ... ok\ntest pikchr ... ok\ntest next_heading_at_same_level_starts_new_scenario ... ok\ntest recall_values_for_use_in_later_steps ... ok\ntest roadmap ... ok\ntest running_only_chosen_scenarios_with_python ... ok\ntest scenario_before_the_first_heading ... ok\ntest scenario_titles ... ok\ntest set_environment_variables_in_generated_test_programs ... ok\ntest simple_patterns_with_regex_metacharacters__allowed_case ... ok\ntest simple_patterns_with_regex_metacharacters__forbidden_case ... ok\ntest smoke_test ... ok\ntest steps_which_do_not_case_sensitively_match_sensitive_bindings_do_not_work ... ok\ntest steps_which_do_not_match_bindings_do_not_work ... ok\ntest steps_which_match_more_than_one_binding_do_not_work ... ok\ntest plantuml ... ok\ntest subheadings_don_t_start_new_scenario ... ok\ntest temporary_files_in_scenarios_in_python ... ok\ntest subplot_accepts_title_and_headings_with_inline_markup ... ok\ntest title_markup ... ok\n\ntest result: ok. 64 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 1.71s\n\n\nrunning 3 tests\ntest embedded_files ... ok\ntest data_directory ... ok\ntest fundamentals ... ok\n\ntest result: ok. 3 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 0 tests\n\ntest result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n\nrunning 6 tests\ntest src/bindings.rs - bindings::BindingImpl::cleanup (line 163) ... ignored\ntest src/bindings.rs - bindings::BindingImpl::function (line 151) ... ignored\ntest src/bindings.rs - bindings::BindingImpl::new (line 137) ... ignored\ntest src/diagrams.rs - diagrams::PikchrMarkup (line 116) ... ok\ntest src/diagrams.rs - diagrams::DotMarkup (line 149) ... ok\ntest src/diagrams.rs - diagrams::PlantumlMarkup (line 198) ... ok\n\ntest result: ok. 3 passed; 0 failed; 3 ignored; 0 measured; 0 filtered out; finished in 2.54s\n\n\nrunning 73 tests\ntest subplotlib/src/file.rs - file::SubplotDataFile (line 20) ... ok\ntest subplotlib/src/file.rs - file::SubplotDataFile::data (line 120) ... ok\ntest subplotlib/src/file.rs - file::SubplotDataFile::name (line 105) ... ok\ntest subplotlib/src/prelude.rs - prelude (line 6) ... ok\ntest subplotlib/src/prelude.rs - prelude::step (line 100) ... ok\ntest subplotlib/src/file.rs - file::SubplotDataFile::new (line 76) ... ok\ntest subplotlib/src/prelude.rs - prelude::step (line 73) ... ok\ntest subplotlib/src/prelude.rs - prelude::throws (line 26) ... ok\ntest subplotlib/src/prelude.rs - prelude::throws (line 39) ... ok\ntest subplotlib/src/scenario.rs - scenario::Scenario (line 305) ... ok\ntest subplotlib/src/step.rs - step::ScenarioStep (line 24) ... ok\ntest subplotlib/src/steplibrary/datadir.rs - steplibrary::datadir::datadir_has_enough_space::call (line 160) ... ignored\ntest subplotlib/src/steplibrary/datadir.rs - steplibrary::datadir::datadir_has_enough_space_megabytes::call (line 171) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::_create_from_embedded_with_other_name_executable::call (line 129) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::create_executable_from_embedded::call (line 93) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::create_executable_from_embedded_with_other_name::call (line 111) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::create_from_embedded::call (line 56) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::create_from_embedded_with_other_name::call (line 70) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::create_from_text::call (line 220) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_and_embedded_file_do_not_match::call (line 469) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_and_embedded_file_match::call (line 443) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_contains::call (line 341) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_do_not_match::call (line 417) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_does_not_exist::call (line 296) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_doesnt_contain::call (line 357) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_exists::call (line 276) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_match::call (line 390) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::file_matches_regex::call (line 374) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::has_different_metadata::call (line 544) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::has_remembered_metadata::call (line 505) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::make_directory::call (line 609) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::mtime_is_ancient::call (line 593) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::mtime_is_recent::call (line 577) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::only_these_exist::call (line 322) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::path_does_not_exist::call (line 659) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::path_exists::call (line 642) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::path_is_empty::call (line 678) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::path_is_not_empty::call (line 696) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::remember_metadata::call (line 231) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::remove_directory::call (line 619) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::remove_empty_directory::call (line 630) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::remove_file::call (line 181) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::touch::call (line 255) ... ignored\ntest subplotlib/src/steplibrary/files.rs - steplibrary::files::touch_with_timestamp::call (line 193) ... ignored\ntest subplotlib/src/steplibrary.rs - steplibrary (line 10) ... ok\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::exit_code_is::call (line 403) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::exit_code_is_nonzero::call (line 442) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::exit_code_is_not::call (line 419) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::exit_code_is_zero::call (line 431) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::helper_script::call (line 227) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::helper_srcdir_path::call (line 241) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::run::call (line 254) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::run_in::call (line 271) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::set_environment_variable::call (line 677) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_contains::call (line 594) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_doesnt_contain::call (line 607) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_doesnt_match_regex::call (line 663) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_is::call (line 542) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_isnt::call (line 555) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stderr_matches_regex::call (line 649) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdin_from_file::call (line 480) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdin_is::call (line 502) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_contains::call (line 568) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_doesnt_contain::call (line 581) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_doesnt_match_regex::call (line 635) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_is::call (line 516) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_isnt::call (line 529) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::stdout_matches_regex::call (line 621) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::try_to_run::call (line 285) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::try_to_run_in::call (line 298) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::unset_environment_variable::call (line 691) ... ignored\ntest subplotlib/src/steplibrary/runcmd.rs - steplibrary::runcmd::Runcmd::join_paths (line 155) ... ok\ntest subplotlib/src/utils.rs - utils::base64_decode (line 9) ... ok\n\ntest result: ok. 14 passed; 0 failed; 59 ignored; 0 measured; 0 filtered out; finished in 2.38s\n\n\nrunning 0 tests\n\ntest result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n/ci/src/inst/subplot --resources /ci/src/share codegen subplot.subplot -o test.py --template python\nrm -f test.log\npython3 test.py --log test.log --env SUBPLOT_DIR=/ci/src/inst \nsrcdir /ci/src\ndatadir /tmp/tmpwe1bqr7n\nscenario: Smoke test\n step 1: given file simple.subplot\n step 2: given file simple.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot docgen simple.subplot -o simple.html\n step 7: then file simple.html exists\n step 8: when I run subplot codegen --run simple.subplot -o test.py\n step 9: then scenario \"Simple\" was run\n step 10: then step \"given precondition foo\" was run\n step 11: then step \"when I do bar\" was run\n step 12: then step \"then bar was done\" was run\n step 13: then command is successful\n cleanup 5: given an installed subplot\nscenario: Indented scenario steps are not allowed\n step 1: given file indented-step.subplot\n step 2: given file indented-step.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I try to run subplot docgen indented-step.subplot -o foo.html\n step 6: then command fails\n step 7: then stderr contains \"indented\"\n cleanup 4: given an installed subplot\nscenario: Next heading at same level starts new scenario\n step 1: given file samelevelisnewscenario.subplot\n step 2: given file samelevelisnewscenario.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run samelevelisnewscenario.subplot -o test.py\n step 7: then scenario \"heading 1.1.1\" was run\n step 8: then scenario \"heading 1.1.2\" was run\n step 9: then command is successful\n cleanup 5: given an installed subplot\nscenario: Misuse of continuation keywords\n step 1: given file continuationmisuse.subplot\n step 2: given file continuationmisuse.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I try to run subplot codegen --run continuationmisuse.subplot -o test.py\n step 7: then command fails\n cleanup 5: given an installed subplot\nscenario: Named code blocks must have an appropriate class\n step 1: given file named-code-blocks-appropriate.subplot\n step 2: given file named-code-blocks-appropriate.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I try to run subplot docgen named-code-blocks-appropriate.subplot -o foo.html\n step 6: then command fails\n step 7: then stderr contains \"#example-1 at named-code-blocks-appropriate.md:7:1\"\n step 8: then stderr doesn't contain \"example-2\"\n step 9: then stderr doesn't contain \"example-3\"\n cleanup 4: given an installed subplot\nscenario: Extract embedded file\n step 1: given file embedded.subplot\n step 2: given file embedded.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen --merciful embedded.subplot -o foo.html\n step 5: then file foo.html exists\n step 6: then file foo.html matches regex /embedded\\\\.txt/\n cleanup 3: given an installed subplot\nscenario: Bad \"add-newline\" value\n step 1: given an installed subplot\n step 2: given file add-newline.subplot\n step 3: given file add-newline.md\n step 4: when I try to run subplot docgen add-newline.subplot -o /dev/null\n step 5: then command fails\n step 6: then stderr contains \"ERROR add-newline.md:1:1: value of add-newline attribute is not understood: xyzzy\"\n cleanup 1: given an installed subplot\nscenario: Code generator gives an error if input document lacks title\n step 1: given file notitle.subplot\n step 2: given file notitle.md\n step 3: given an installed subplot\n step 4: when I try to run subplot codegen --run notitle.subplot -o test.py\n step 5: then command fails\n cleanup 3: given an installed subplot\nscenario: Document generator gives an error if input document lacks title\n step 1: given file notitle.subplot\n step 2: given file notitle.md\n step 3: given an installed subplot\n step 4: when I try to run subplot docgen notitle.subplot -o foo.md\n step 5: then command fails\n cleanup 3: given an installed subplot\nscenario: Missing functions file\n step 1: given file missing-functions.subplot\n step 2: given file missing-functions.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I try to run subplot codegen --run missing-functions.subplot -o foo.py\n step 6: then command fails\n step 7: then stderr contains \"could not be found\"\n step 8: then stderr contains \"missing-functions.py\"\n cleanup 4: given an installed subplot\nscenario: Empty lines in scenarios\n step 1: given file emptylines.subplot\n step 2: given file emptylines.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot docgen emptylines.subplot -o emptylines.html\n step 7: then file emptylines.html exists\n step 8: when I run subplot codegen --run emptylines.subplot -o test.py\n step 9: then scenario \"Simple\" was run\n step 10: then step \"given precondition foo\" was run\n step 11: then step \"when I do bar\" was run\n step 12: then step \"then bar was done\" was run\n step 13: then command is successful\n cleanup 5: given an installed subplot\nscenario: Attempt to use definition list\n step 1: given an installed subplot\n step 2: given file dl.subplot\n step 3: given file dl.md\n step 4: when I try to run subplot docgen dl.subplot -o /dev/null\n step 5: then command fails\n step 6: then stderr contains \"ERROR dl.md:3:1: attempt to use definition lists in Markdown\"\n cleanup 1: given an installed subplot\nscenario: Extract embedded file, by default add missing newline\n step 1: given file default-without-newline.txt\n step 2: then default-without-newline.txt ends in one newline\nscenario: Extract embedded file, do not automatically add second newline\n step 1: given file auto-has-newline.txt\n step 2: then auto-has-newline.txt ends in one newline\nscenario: Cleanup functions gets called on success (Python)\n step 1: given file cleanup-success-python.subplot\n step 2: given file cleanup-success-python.md\n step 3: given file cleanup.yaml\n step 4: given file cleanup.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run cleanup-success-python.subplot -o test.py\n step 7: then scenario \"Cleanup\" was run\n step 8: then step \"given foo\" was run, and then step \"given bar\"\n step 9: then cleanup for \"given bar\" was run, and then for \"given foo\"\n step 10: then command is successful\n cleanup 5: given an installed subplot\nscenario: Capture using regular expressions\n step 1: given file regex.subplot\n step 2: given file regex.md\n step 3: given file regex.yaml\n step 4: given file capture.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run regex.subplot -o test.py\n step 7: then scenario \"Regex\" was run\n step 8: then step \"given I am Tomjon\" was run\n step 9: then stdout contains \"function got argument name as Tomjon\"\n step 10: then command is successful\n cleanup 5: given an installed subplot\nscenario: CSS URLs\n step 1: given file css-urls.subplot\n step 2: given file css-urls.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I run subplot docgen css-urls.subplot -o foo.html\n step 6: then file foo.html contains \"https://example.com/flushing.css\"\n cleanup 4: given an installed subplot\nscenario: Date given in metadata\n step 1: given file metadate.subplot\n step 2: given file metadate.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen metadate.subplot -o metadate.html\n step 5: when I run cat metadate.html\n step 6: then file metadate.html exists\n step 7: then file metadate.html contains \"<title>The Fabulous Title</title>\"\n step 8: then file metadate.html contains \"Alfred Pennyworth\"\n step 9: then file metadate.html contains \"Geoffrey Butler\"\n step 10: then file metadate.html contains \"WIP\"\n cleanup 3: given an installed subplot\nscenario: Examples are not files\n step 1: given file examplesnotfiles.subplot\n step 2: given file examplesnotfiles.md\n step 3: given an installed subplot\n step 4: when I try to run subplot codegen examplesnotfiles.subplot -t python -o examplesnotfiles.html\n step 5: then command fails\n step 6: then file examplesnotfiles.html does not exist\n step 7: then stderr contains \"thisisanexample.txt\"\n cleanup 3: given an installed subplot\nscenario: Extract embedded file, automatically add missing newline\n step 1: given file auto-without-newline.txt\n step 2: then auto-without-newline.txt ends in one newline\nscenario: Fail if two filenames only differ in case\n step 1: given file casediff.md\n step 2: given an installed subplot\n step 3: when I try to run subplot docgen casediff.md -o casediff.html\n step 4: then command fails\n step 5: then file casediff.html does not exist\n cleanup 2: given an installed subplot\nscenario: Running only chosen scenarios with Python\n step 1: given file twoscenarios-python.subplot\n step 2: given file twoscenarios-python.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen twoscenarios-python.subplot -o test.py\n step 7: when I run python3 test.py on\n step 8: then scenario \"One\" was run\n step 9: then scenario \"Two\" was not run\n step 10: then command is successful\n cleanup 5: given an installed subplot\nscenario: Subplot accepts title and headings with inline markup\n step 1: given file fancytitle.subplot\n step 2: given file fancytitle.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I try to run subplot docgen fancytitle.subplot -o foo.md\n step 7: then command is successful\n step 8: when I try to run subplot codegen fancytitle.subplot -o foo.md\n step 9: then command is successful\n cleanup 5: given an installed subplot\nscenario: No date anywhere\n step 1: given file dateless.subplot\n step 2: given file dateless.md\n step 3: given file dateless.md has modification time 2020-02-26 07:53:17\n step 4: given an installed subplot\n step 5: when I run subplot docgen dateless.subplot -o mtime.html\n step 6: then file mtime.html exists\n step 7: then file mtime.html contains \"<title>The Fabulous Title</title>\"\n step 8: then file mtime.html contains \"Alfred Pennyworth\"\n step 9: then file mtime.html contains \"Geoffrey Butler\"\n step 10: then file mtime.html contains \"2020-02-26 07:53\"\n cleanup 4: given an installed subplot\nscenario: Scenario before the first heading\n step 1: given an installed subplot\n step 2: given file scenario-before-heading.subplot\n step 3: given file scenario-before-heading.md\n step 4: when I try to run subplot docgen scenario-before-heading.subplot -o /dev/null\n step 5: then command fails\n step 6: then stderr contains \"ERROR scenario-before-heading.md:1:1: first scenario is before first heading\"\n cleanup 1: given an installed subplot\nscenario: All the keywords\n step 1: given file allkeywords.subplot\n step 2: given file allkeywords.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run allkeywords.subplot -o test.py\n step 7: then scenario \"All keywords\" was run\n step 8: then step \"given precondition foo\" was run\n step 9: then step \"when I do bar\" was run\n step 10: then step \"then bar was done\" was run\n step 11: then command is successful\n cleanup 5: given an installed subplot\nscenario: Extract embedded file, by default do not add a second newline\n step 1: given file default-has-newline.txt\n step 2: then default-has-newline.txt ends in one newline\nscenario: Title markup\n step 1: given file title-markup.subplot\n step 2: given file title-markup.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen title-markup.subplot -o foo.html\n step 5: then file foo.html exists\n cleanup 3: given an installed subplot\nscenario: Dot\n step 1: given file dot.subplot\n step 2: given file dot.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I run subplot docgen dot.subplot -o dot.html\n step 6: then file dot.html matches regex /src=\"data:image/svg\\\\+xml;base64,/\n cleanup 4: given an installed subplot\nscenario: Date given on command line\n step 1: given file dateless.subplot\n step 2: given file dateless.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen dateless.subplot -o dateoption.html --date=FANCYDATE\n step 5: then file dateoption.html exists\n step 6: then file dateoption.html contains \"<title>The Fabulous Title</title>\"\n step 7: then file dateoption.html contains \"Alfred Pennyworth\"\n step 8: then file dateoption.html contains \"Geoffrey Butler\"\n step 9: then file dateoption.html contains \"FANCYDATE\"\n cleanup 3: given an installed subplot\nscenario: Steps which do not case-sensitively match sensitive bindings do not work\n step 1: given file casemismatch.subplot\n step 2: given file casemismatch.md\n step 3: given file badbindings.yaml\n step 4: given an installed subplot\n step 5: when I try to run subplot codegen --run casemismatch.subplot -o test.py\n step 6: then command fails\n cleanup 4: given an installed subplot\nscenario: Lowest level heading is name of scenario\n step 1: given file scenarioislowest.subplot\n step 2: given file scenarioislowest.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run scenarioislowest.subplot -o test.py\n step 7: then scenario \"heading 1.1.1\" was run\n step 8: then command is successful\n cleanup 5: given an installed subplot\nscenario: Extract embedded file, explicitly add missing newline\n step 1: given file add-without-newline.txt\n step 2: then add-without-newline.txt ends in one newline\nscenario: Recall values for use in later steps\n step 1: given file values.subplot\n step 2: given file values.md\n step 3: given file values.yaml\n step 4: given file values.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen values.subplot -o test.py\n step 7: when I run python3 test.py\n step 8: then command is successful\n cleanup 5: given an installed subplot\nscenario: PlantUML\n step 1: given file plantuml.subplot\n step 2: given file plantuml.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I run subplot docgen plantuml.subplot -o plantuml.html\n step 6: then file plantuml.html matches regex /src=\"data:image/svg\\\\+xml;base64,/\n cleanup 4: given an installed subplot\nscenario: Extract embedded files\n step 1: given file embedded-file.subplot\n step 2: given file embedded-file.md\n step 3: given file expected.txt\n step 4: given an installed subplot\n step 5: when I run subplot extract --merciful embedded-file.subplot foo.txt -d .\n step 6: then files foo.txt and expected.txt match\n cleanup 4: given an installed subplot\nscenario: Temporary files in scenarios in Python\n step 1: given file tmpdir.subplot\n step 2: given file tmpdir.md\n step 3: given file tmpdir.yaml\n step 4: given file tmpdir.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run tmpdir.subplot -o test.py\n step 7: then command is successful\n step 8: then scenario \"TMPDIR\" was run\n step 9: then step \"then TMPDIR is set\" was run\n cleanup 5: given an installed subplot\nscenario: Extract embedded file, explicitly add second newline\n step 1: given file add-has-newline.txt\n step 2: then add-has-newline.txt ends in two newlines\nscenario: Extracting metadata from a document\n step 1: given file images.subplot\n step 2: given file images.md\n step 3: given file b.yaml\n step 4: given file other.yaml\n step 5: given file f.py\n step 6: given file other.py\n step 7: given file expected.json\n step 8: given an installed subplot\n step 9: when I run subplot metadata images.subplot\n step 10: then stdout contains \"source: images.md\"\n step 11: then stdout contains \"source: b.yaml\"\n step 12: then stdout contains \"source: other.yaml\"\n step 13: then stdout contains \"source: f.py\"\n step 14: then stdout contains \"source: other.py\"\n step 15: then stdout contains \"source: image.gif\"\n step 16: then stdout contains \"bindings: b.yaml\"\n step 17: then stdout contains \"bindings: other.yaml\"\n step 18: then stdout contains \"functions[python]: f.py\"\n step 19: when I run subplot metadata images.subplot -o json\n step 20: then JSON output matches expected.json\n cleanup 8: given an installed subplot\nscenario: Embedded CSS\n step 1: given file embedded-css.subplot\n step 2: given file embedded-css.md\n step 3: given file embedded-css.css\n step 4: given file b.yaml\n step 5: given an installed subplot\n step 6: when I run subplot docgen embedded-css.subplot -o foo.html\n step 7: then file foo.html contains \"silly: property;\"\n cleanup 5: given an installed subplot\nscenario: Simple patterns with regex metacharacters: forbidden case\n step 1: given file confusedpattern.subplot\n step 2: given file confusedpattern.md\n step 3: given file confusedpattern.yaml\n step 4: given file capture.py\n step 5: given an installed subplot\n step 6: when I try to run subplot codegen --run confusedpattern.subplot -o test.py\n step 7: then command fails\n step 8: then stderr contains \"simple pattern contains regex\"\n cleanup 5: given an installed subplot\nscenario: Duplicate scenario titles\n step 1: given file duplicate-scenario-titles.subplot\n step 2: given file duplicate-scenario-titles.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I try to run subplot metadata duplicate-scenario-titles.subplot\n step 7: then command fails\n step 8: then stderr contains \"duplicate\"\n cleanup 5: given an installed subplot\nscenario: List embedded files\n step 1: given file two-embedded.subplot\n step 2: given file two-embedded.md\n step 3: given an installed subplot\n step 4: when I run subplot metadata --merciful two-embedded.subplot\n step 5: then stdout contains \"foo.txt\"\n step 6: then stdout contains \"bar.yaml\"\n cleanup 3: given an installed subplot\nscenario: Fail if embedded file isn't used\n step 1: given file unusedfile.subplot\n step 2: given file unusedfile.md\n step 3: given an installed subplot\n step 4: when I try to run subplot docgen --merciful unusedfile.subplot -o unusedfile.html\n step 5: then command is successful\n step 6: then file unusedfile.html exists\n step 7: then stderr contains \"thisisnotused.txt\"\n cleanup 3: given an installed subplot\nscenario: Scenario titles\n step 1: given file scenario-titles.subplot\n step 2: given file scenario-titles.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot metadata scenario-titles.subplot\n step 7: then stdout contains \"My fun scenario title\"\n cleanup 5: given an installed subplot\nscenario: Next heading at higher level starts new scenario\n step 1: given file higherisnewscenario.subplot\n step 2: given file higherisnewscenario.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run higherisnewscenario.subplot -o test.py\n step 7: then scenario \"heading 1.1.1\" was run\n step 8: then scenario \"heading 1.2\" was run\n step 9: then command is successful\n cleanup 5: given an installed subplot\nscenario: Steps which do not match bindings do not work\n step 1: given file nobinding.subplot\n step 2: given file nobinding.md\n step 3: given file badbindings.yaml\n step 4: given an installed subplot\n step 5: when I try to run subplot codegen --run nobinding.subplot -o test.py\n step 6: then command fails\n cleanup 4: given an installed subplot\nscenario: Subheadings don't start new scenario\n step 1: given file subisnotnewscenario.subplot\n step 2: given file subisnotnewscenario.md\n step 3: given file b.yaml\n step 4: given file f.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run subisnotnewscenario.subplot -o test.py\n step 7: then scenario \"heading 1.1a\" was run\n step 8: then command is successful\n cleanup 5: given an installed subplot\nscenario: Pikchr\n step 1: given file pikchr.subplot\n step 2: given file pikchr.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen pikchr.subplot -o pikchr.html\n step 5: then file pikchr.html matches regex /src=\"data:image/svg\\\\+xml;base64,/\n cleanup 3: given an installed subplot\nscenario: No scenarios means codegen fails\n step 1: given file noscenarios.subplot\n step 2: given file noscenarios.md\n step 3: given an installed subplot\n step 4: when I try to run subplot codegen noscenarios.subplot -o test.py\n step 5: then command fails\n step 6: then stderr contains \"no scenarios were found\"\n cleanup 3: given an installed subplot\nscenario: Examples may be unused\n step 1: given file unusedexample.subplot\n step 2: given file unusedexample.md\n step 3: given an installed subplot\n step 4: when I try to run subplot docgen --merciful unusedexample.subplot -o unusedexample.html\n step 5: then command is successful\n step 6: then file unusedexample.html exists\n step 7: then stderr doesn't contain \"thisisnotused.txt\"\n cleanup 3: given an installed subplot\nscenario: Fail if the same filename is used twice\n step 1: given file onefiletwice.md\n step 2: given an installed subplot\n step 3: when I try to run subplot docgen onefiletwice.md -o onefiletwice.html\n step 4: then command fails\n step 5: then file onefiletwice.html does not exist\n cleanup 2: given an installed subplot\nscenario: No template means you can docgen but not codegen\n step 1: given file notemplate.subplot\n step 2: given file notemplate.md\n step 3: given an installed subplot\n step 4: when I run subplot docgen notemplate.subplot -o notemplate.html\n step 5: then file notemplate.html exists\n step 6: when I try to run subplot codegen notemplate.subplot -o test.py\n step 7: then command fails\n step 8: then stderr contains \"document has no template\"\n cleanup 3: given an installed subplot\nscenario: Missing bindings file\n step 1: given file missing-binding.subplot\n step 2: given file missing-binding.md\n step 3: given an installed subplot\n step 4: when I try to run subplot docgen missing-binding.subplot -o foo.html\n step 5: then command fails\n step 6: then stderr contains \"could not be found\"\n step 7: then stderr contains \"missing-binding.yaml\"\n cleanup 3: given an installed subplot\nscenario: Cleanup functions get called on failure (Python)\n step 1: given file cleanup-fail-python.subplot\n step 2: given file cleanup-fail-python.md\n step 3: given file cleanup.yaml\n step 4: given file cleanup.py\n step 5: given an installed subplot\n step 6: when I try to run subplot codegen --run cleanup-fail-python.subplot -o test.py\n step 7: then scenario \"Cleanup\" was run\n step 8: then step \"given foo\" was run, and then step \"given bar\"\n step 9: then cleanup for \"given bar\" was run, and then for \"given foo\"\n step 10: then cleanup for \"given failure\" was not run\n step 11: then command fails\n cleanup 5: given an installed subplot\nscenario: Class name validation\n step 1: given file unknown-class-name.subplot\n step 2: given file unknown-class-name.md\n step 3: given file known-class-name.subplot\n step 4: given file known-class-name.md\n step 5: given file b.yaml\n step 6: given an installed subplot\n step 7: when I try to run subplot docgen unknown-class-name.subplot -o unknown-class-name.html\n step 8: then command fails\n step 9: then file unknown-class-name.html does not exist\n step 10: then stderr contains \"Unknown classes found in the document: foobar\"\n step 11: when I run subplot docgen known-class-name.subplot -o known-class-name.html\n step 12: then file known-class-name.html exists\n cleanup 6: given an installed subplot\nscenario: Multiple markdown files\n step 1: given file multimd.subplot\n step 2: given file md1.md\n step 3: given file md2.md\n step 4: given an installed subplot\n step 5: when I run subplot docgen multimd.subplot -o multimd.html\n step 6: when I run cat multimd.html\n step 7: then file multimd.html exists\n step 8: then file multimd.html contains \"<title>The Fabulous Title</title>\"\n step 9: then file multimd.html contains \"First markdown file.\"\n step 10: then file multimd.html contains \"Second markdown file.\"\n cleanup 4: given an installed subplot\nscenario: Files not in current working directory\n step 1: given file x/simple.subplot from simple.subplot\n step 2: given file x/simple.md from simple.md\n step 3: given file x/b.yaml from b.yaml\n step 4: given file x/f.py from f.py\n step 5: given an installed subplot\n step 6: when I run subplot metadata x/simple.subplot\n step 7: then command is successful\n step 8: when I run subplot codegen x/simple.subplot -o test.py\n step 9: then file test.py exists\n step 10: when I run subplot docgen x/simple.subplot -o simple.html\n step 11: then file simple.html exists\n cleanup 5: given an installed subplot\nscenario: Roadmap\n step 1: given file roadmap.subplot\n step 2: given file roadmap.md\n step 3: given file b.yaml\n step 4: given an installed subplot\n step 5: when I run subplot docgen roadmap.subplot -o roadmap.html\n step 6: then file roadmap.html matches regex /src=\"data:image/svg\\\\+xml;base64,/\n cleanup 4: given an installed subplot\nscenario: Simple patterns with regex metacharacters: allowed case\n step 1: given file confusedbutok.subplot\n step 2: given file confusedbutok.md\n step 3: given file confusedbutok.yaml\n step 4: given file capture.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run confusedbutok.subplot -o test.py\n step 7: then command is successful\n cleanup 5: given an installed subplot\nscenario: Set environment variables in generated test programs\n step 1: given file env.subplot\n step 2: given file env.md\n step 3: given file env.yaml\n step 4: given file env.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen env.subplot -o test.py\n step 7: when I try to run python3 test.py\n step 8: then command fails\n step 9: when I try to run python3 test.py --env FOO=foo\n step 10: then command fails\n step 11: when I try to run python3 test.py --env FOO=bar\n step 12: then command is successful\n cleanup 5: given an installed subplot\nscenario: Extract embedded file, do not add missing newline\n step 1: given file no-adding-without-newline.txt\n step 2: then no-adding-without-newline.txt does not end in a newline\nscenario: Steps which match more than one binding do not work\n step 1: given file twobindings.subplot\n step 2: given file twobindings.md\n step 3: given file twobindings.yaml\n step 4: given file a_function.py\n step 5: given an installed subplot\n step 6: when I try to run subplot codegen --run twobindings.subplot -o test.py\n step 7: then command fails\n step 8: then stderr contains \"xyzzy\"\n step 9: then stderr contains \"plugh\"\n cleanup 5: given an installed subplot\nscenario: Capture using simple patterns\n step 1: given file simplepattern.subplot\n step 2: given file simplepattern.md\n step 3: given file simplepattern.yaml\n step 4: given file capture.py\n step 5: given an installed subplot\n step 6: when I run subplot codegen --run simplepattern.subplot -o test.py\n step 7: then scenario \"Simple pattern\" was run\n step 8: then step \"given I am Tomjon\" was run\n step 9: then stdout contains \"function got argument name as Tomjon\"\n step 10: then command is successful\n cleanup 5: given an installed subplot\nOK, all scenarios finished successfully\ncd examples/muck && /ci/src/inst/subplot --resources /ci/src/share codegen muck.subplot --run --output test.py\nsrcdir /ci/src/examples/muck\ndatadir /tmp/tmprdw_pjm7\nscenario: Updating someone else's data\n step 1: given a fresh Muck server\n step 2: given I am Tomjon\n step 3: when I do POST /res with {\"foo\": \"bar\"}\n step 4: then header Muck-Id is ID\n step 5: then header Muck-Revision is REV1\n step 6: given I am Verence\n step 7: when I do PUT /res with Muck-Id: {ID}, Muck-Revision: {REV1}, and body {\"foo\":\"yo\"}\n step 8: then response code is 404\nscenario: Accessing someone else's data\n step 1: given a fresh Muck server\n step 2: given I am Tomjon\n step 3: when I do POST /res with {\"foo\": \"bar\"}\n step 4: then header Muck-Id is ID\n step 5: then header Muck-Revision is REV1\n step 6: when I do GET /res with Muck-Id: {ID}\n step 7: then response code is 200\n step 8: then header Muck-Revision matches {REV1}\n step 9: then body matches {\"foo\": \"bar\"}\n step 10: given I am Verence\n step 11: when I do GET /res with Muck-Id: {ID}\n step 12: then response code is 404\nscenario: Basic object handling\n step 1: given a fresh Muck server\n step 2: given I am Tomjon\n step 3: when I do POST /res with {\"foo\": \"bar\"}\n step 4: then response code is 201\n step 5: then header Muck-Id is ID\n step 6: then header Muck-Revision is REV1\n step 7: when I do GET /res with Muck-Id: {ID}\n step 8: then response code is 200\n step 9: then header Muck-Revision matches {REV1}\n step 10: then body matches {\"foo\": \"bar\"}\n step 11: when I do PUT /res with Muck-Id: {ID}, Muck-Revision: {REV1}, and body {\"foo\":\"yo\"}\n step 12: then response code is 200\n step 13: then header Muck-Revision is {REV2}\n step 14: then revisions {REV1} and {REV2} are different\n step 15: when I do PUT /res with Muck-Id: {ID}, Muck-Revision: {REV1}, and body {\"foo\":\"yo\"}\n step 16: then response code is 409\n step 17: when I do GET /res with Muck-Id: {ID}\n step 18: then response code is 200\n step 19: then header Muck-Revision matches {REV2}\n step 20: then body matches {\"foo\": \"yo\"}\n step 21: when I do DELETE /res with Muck-Id: {ID}\n step 22: then response code is 200\n step 23: when I do GET /res with Muck-Id: {ID}\n step 24: then response code is 404\nscenario: Deleting someone else's data\n step 1: given a fresh Muck server\n step 2: given I am Tomjon\n step 3: when I do POST /res with {\"foo\": \"bar\"}\n step 4: then header Muck-Id is ID\n step 5: then header Muck-Revision is REV1\n step 6: given I am Verence\n step 7: when I do DELETE /res with Muck-Id: {ID}\n step 8: then response code is 404\nscenario: Restarting Muck\n step 1: given a fresh Muck server\n step 2: given I am Tomjon, with super capability\n step 3: when I do POST /res with {\"foo\": \"bar\"}\n step 4: then header Muck-Id is ID\n step 5: then header Muck-Revision is REV1\n step 6: when I restart Muck\n step 7: when I do GET /res with Muck-Id: {ID}\n step 8: then response code is 200\n step 9: then header Muck-Revision matches {REV1}\n step 10: then body matches {\"foo\": \"bar\"}\nOK, all scenarios finished successfully\nif [ \"--offline\" = \"\" ] ; then \\\n\tcd examples/website && \\\n\t/ci/src/inst/subplot --resources /ci/src/share codegen website.subplot --run --output test.py; \\\nfi\ncd examples/seq && cargo test -- \n\nrunning 4 tests\ntest no_arguments ... ok\ntest more_than_one_number ... ok\ntest not_a_number ... ok\ntest one_number ... ok\n\ntest result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s\n\n/ci/src/inst/subplot --resources /ci/src/share docgen subplot.subplot -o subplot.html\n/ci/src/inst/subplot --resources /ci/src/share docgen tests/subplots/common/files.subplot -o tests/subplots/common/files.html\n/ci/src/inst/subplot --resources /ci/src/share docgen tests/subplots/common/runcmd.subplot -o tests/subplots/common/runcmd.html\ncd examples/muck && /ci/src/inst/subplot --resources /ci/src/share/subplot docgen muck.subplot -o muck.html\ncd examples/website && /ci/src/inst/subplot --resources /ci/src/share docgen website.subplot -o website.html\ncd examples/seq && /ci/src/inst/subplot --resources /ci/src/share docgen seq.subplot -o seq.html\n/ci/src/inst/subplot --resources /ci/src/share libdocgen lib/runcmd.yaml --output /ci/src/inst/runcmd.md\nif which pandoc>/dev/null; then pandoc --toc --standalone --self-contained --metadata \"title=lib/runcmd\" --output /ci/src/inst/runcmd.html /ci/src/inst/runcmd.md; fi\n/ci/src/inst/subplot --resources /ci/src/share libdocgen lib/files.yaml --output /ci/src/inst/files.md\nif which pandoc>/dev/null; then pandoc --toc --standalone --self-contained --metadata \"title=lib/files\" --output /ci/src/inst/files.html /ci/src/inst/files.md; fi\n/ci/src/inst/subplot --resources /ci/src/share libdocgen python/lib/daemon.yaml --output /ci/src/inst/daemon.md\nif which pandoc>/dev/null; then pandoc --toc --standalone --self-contained --metadata \"title=lib/daemon\" --output /ci/src/inst/daemon.html /ci/src/inst/daemon.md; fi\n/ci/src/inst/subplot --resources /ci/src/share docgen book/user-guide.subplot --output book/user-guide.html\nmkdir -p doc/libdocs\nfor x in subplot.html tests/subplots/common/*.html examples/*/*.html book/*.html; do if [ -e \"$x\" ]; then mv \"$x\" doc; fi; done\nfor x in /ci/src/inst/*.html; do if [ -e \"$x\" ]; then mv \"$x\" doc/libdocs/; fi; done\nHEAD is now at cfebfc9 Merge branch 'fix-ci' into 'main'\nRemoving doc/\nRemoving examples/muck/test.py\nRemoving inst/\nRemoving share/python/template/__pycache__/\nRemoving test.log\nRemoving test.py\nHEAD detached at cfebfc9\nnothing to commit, working tree clean\n",
"stderr": "+ make OFFLINE=--offline\n Compiling subplot v0.14.0 (/ci/src)\n Compiling subplotlib v0.14.0 (/ci/src/subplotlib)\n Compiling subplotlib-derive v0.14.0 (/ci/src/subplotlib-derive)\n Checking subplot-bin v0.14.0 (/ci/src/bin)\n Checking subplot-seq-example v0.1.0 (/ci/src/examples/seq)\n Finished `dev` profile [unoptimized + debuginfo] target(s) in 4.15s\n Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.09s\n Installing subplot-bin v0.14.0 (/ci/src/bin)\n Compiling proc-macro2 v1.0.103\n Compiling unicode-ident v1.0.22\n Compiling quote v1.0.42\n Compiling cfg-if v1.0.4\n Compiling memchr v2.7.6\n Compiling zerocopy v0.8.31\n Compiling syn v2.0.111\n Compiling once_cell v1.21.3\n Compiling libc v0.2.178\n Compiling serde_core v1.0.228\n Compiling aho-corasick v1.1.4\n Compiling version_check v0.9.5\n Compiling regex-syntax v0.8.8\n Compiling ahash v0.8.12\n Compiling regex-automata v0.4.13\n Compiling itoa v1.0.15\n Compiling crossbeam-utils v0.8.21\n Compiling anyhow v1.0.100\n Compiling serde v1.0.228\n Compiling bitflags v2.10.0\n Compiling log v0.4.29\n Compiling serde_derive v1.0.228\n Compiling encoding_rs v0.8.35\n Compiling doc-comment v0.3.4\n Compiling ucd-trie v0.1.7\n Compiling arraydeque v0.5.1\n Compiling pest v2.8.4\n Compiling crossbeam-epoch v0.9.18\n Compiling hashbrown v0.14.5\n Compiling getrandom v0.2.16\n Compiling bstr v1.12.1\n Compiling foldhash v0.1.5\n Compiling shlex v1.3.0\n Compiling rustix v1.1.2\n Compiling time-core v0.1.6\n Compiling same-file v1.0.6\n Compiling utf8parse v0.2.2\n Compiling unicode-width v0.2.2\n Compiling getrandom v0.3.4\n Compiling libm v0.2.15\n Compiling find-msvc-tools v0.1.5\n Compiling num-conv v0.1.0\n Compiling time-macros v0.2.24\n Compiling cc v1.2.49\n Compiling anstyle-parse v0.2.7\n Compiling walkdir v2.5.0\n Compiling hashbrown v0.15.5\n Compiling globset v0.4.18\n Compiling hashlink v0.9.1\n Compiling rand_core v0.6.4\n Compiling pest_meta v2.8.4\n Compiling crossbeam-deque v0.8.6\n Compiling serde_path_to_error v0.1.20\n Compiling ppv-lite86 v0.2.21\n Compiling tracing-core v0.1.36\n Compiling powerfmt v0.2.0\n Compiling colorchoice v1.0.4\n Compiling linux-raw-sys v0.11.0\n Compiling lazy_static v1.5.0\n Compiling anstyle v1.0.13\n Compiling thiserror v2.0.17\n Compiling serde_json v1.0.145\n Compiling is_terminal_polyfill v1.70.2\n Compiling anstyle-query v1.1.5\n Compiling anstream v0.6.21\n Compiling deranged v0.5.5\n Compiling rand_chacha v0.3.1\n Compiling pest_generator v2.8.4\n Compiling ignore v0.4.25\n Compiling yaml-rust2 v0.9.0\n Compiling hashlink v0.10.0\n Compiling pikchr v0.1.4\n Compiling thiserror-impl v2.0.17\n Compiling tracing-attributes v0.1.31\n Compiling clap_lex v0.7.6\n Compiling deunicode v1.6.2\n Compiling heck v0.5.0\n Compiling strsim v0.11.1\n Compiling smawk v0.3.2\n Compiling fastrand v2.3.0\n Compiling ryu v1.0.20\n Compiling pulldown-cmark v0.13.0\n Compiling unicode-linebreak v0.1.5\n Compiling pin-project-lite v0.2.16\n Compiling tracing v0.1.44\n Compiling textwrap v0.16.2\n Compiling tempfile v3.23.0\n Compiling clap_builder v4.5.53\n Compiling clap_derive v4.5.49\n Compiling slug v0.1.6\n Compiling time v0.3.44\n Compiling humansize v2.1.3\n Compiling yaml-rust2 v0.10.4\n Compiling marked-yaml v0.7.2\n Compiling globwalk v0.9.1\n Compiling pest_derive v2.8.4\n Compiling subplot v0.14.0 (/ci/src)\n Compiling rand v0.8.5\n Compiling getopts v0.2.24\n Compiling regex v1.12.2\n Compiling utf8-width v0.1.8\n Compiling percent-encoding v2.3.2\n Compiling pulldown-cmark-escape v0.11.0\n Compiling unicode-segmentation v1.12.0\n Compiling unicase v2.8.1\n Compiling git-testament-derive v0.2.1\n Compiling tera v1.20.1\n Compiling html-escape v0.2.13\n Compiling roadmap v0.7.0\n Compiling marked-yaml v0.8.0\n Compiling clap v4.5.53\n Compiling sharded-slab v0.1.7\n Compiling tracing-log v0.2.0\n Compiling matchers v0.2.0\n Compiling thread_local v1.1.9\n Compiling descape v3.0.0\n Compiling line-col v0.2.1\n Compiling nu-ansi-term v0.50.3\n Compiling base64 v0.22.1\n Compiling smallvec v1.15.1\n Compiling tracing-subscriber v0.3.22\n Compiling git-testament v0.2.6\n Compiling subplot-bin v0.14.0 (/ci/src/bin)\n Finished `dev` profile [unoptimized + debuginfo] target(s) in 36.06s\n Installing /ci/src/inst/bin/subplot\n Installed package `subplot-bin v0.14.0 (/ci/src/bin)` (executable `subplot`)\nwarning: be sure to add `/ci/src/inst/bin` to your PATH to be able to run the installed binaries\n............................\n----------------------------------------------------------------------\nRan 28 tests in 0.001s\n\nOK\n..\n----------------------------------------------------------------------\nRan 2 tests in 0.000s\n\nOK\n Compiling syn v2.0.111\n Compiling libc v0.2.178\n Compiling cfg-if v1.0.4\n Compiling zerocopy v0.8.31\n Compiling once_cell v1.21.3\n Compiling pest_generator v2.8.4\n Compiling serde_core v1.0.228\n Compiling serde_derive v1.0.228\n Compiling thiserror-impl v2.0.17\n Compiling tracing-attributes v0.1.31\n Compiling pest_derive v2.8.4\n Compiling crossbeam-utils v0.8.21\n Compiling ahash v0.8.12\n Compiling aho-corasick v1.1.4\n Compiling bitflags v2.10.0\n Compiling regex-syntax v0.8.8\n Compiling regex-automata v0.4.13\n Compiling encoding_rs v0.8.35\n Compiling serde v1.0.228\n Compiling arraydeque v0.5.1\n Compiling crossbeam-epoch v0.9.18\n Compiling hashbrown v0.14.5\n Compiling getrandom v0.2.16\n Compiling doc-comment v0.3.4\n Compiling bstr v1.12.1\n Compiling foldhash v0.1.5\n Compiling unicode-width v0.2.2\n Compiling hashbrown v0.15.5\n Compiling globset v0.4.18\n Compiling hashlink v0.9.1\n Compiling getrandom v0.3.4\n Compiling rand_core v0.6.4\n Compiling crossbeam-deque v0.8.6\n Compiling serde_path_to_error v0.1.20\n Compiling ppv-lite86 v0.2.21\n Compiling libm v0.2.15\n Compiling rustix v1.1.2\n Compiling linux-raw-sys v0.11.0\n Compiling tempfile v3.23.0\n Compiling rand_chacha v0.3.1\n Compiling ignore v0.4.25\n Compiling yaml-rust2 v0.9.0\n Compiling hashlink v0.10.0\n Compiling serde_json v1.0.145\n Compiling thiserror v2.0.17\n Compiling unicode-linebreak v0.1.5\n Compiling fastrand v2.3.0\n Compiling ryu v1.0.20\n Compiling smawk v0.3.2\n Compiling deunicode v1.6.2\n Compiling textwrap v0.16.2\n Compiling slug v0.1.6\n Compiling time-macros v0.2.24\n Compiling yaml-rust2 v0.10.4\n Compiling marked-yaml v0.7.2\n Compiling globwalk v0.9.1\n Compiling rand v0.8.5\n Compiling humansize v2.1.3\n Compiling getopts v0.2.24\n Compiling regex v1.12.2\n Compiling culpa-macros v1.0.2\n Compiling pulldown-cmark v0.13.0\n Compiling tracing-core v0.1.36\n Compiling pikchr v0.1.4\n Compiling subplot v0.14.0 (/ci/src)\n Compiling pin-project-lite v0.2.16\n Compiling pulldown-cmark-escape v0.11.0\n Compiling percent-encoding v2.3.2\n Compiling unicase v2.8.1\n Compiling cfg_aliases v0.2.1\n Compiling lazy_static v1.5.0\n Compiling utf8-width v0.1.8\n Compiling unicode-segmentation v1.12.0\n Compiling html-escape v0.2.13\n Compiling tera v1.20.1\n Compiling nix v0.29.0\n Compiling tracing v0.1.44\n Compiling roadmap v0.7.0\n Compiling marked-yaml v0.8.0\n Compiling descape v3.0.0\n Compiling line-col v0.2.1\n Compiling base64 v0.22.1\n Compiling culpa v1.0.2\n Compiling cvt v0.1.2\n Compiling time v0.3.44\n Compiling fs_at v0.2.1\n Compiling subplotlib v0.14.0 (/ci/src/subplotlib)\n Compiling normpath v1.5.0\n Compiling remove_dir_all v1.0.0\n Compiling filetime v0.2.26\n Compiling fs2 v0.4.3\n Compiling state v0.6.0\n Compiling shell-words v1.1.1\n Compiling subplotlib-derive v0.14.0 (/ci/src/subplotlib-derive)\n Compiling clap_derive v4.5.49\n Compiling clap v4.5.53\n Compiling git-testament-derive v0.2.1\n Compiling tracing-subscriber v0.3.22\n Compiling git-testament v0.2.6\n Compiling subplot-bin v0.14.0 (/ci/src/bin)\n Compiling subplot-seq-example v0.1.0 (/ci/src/examples/seq)\n Finished `test` profile [unoptimized + debuginfo] target(s) in 43.66s\n Running unittests src/lib.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot-4eb51c1e86149cc7)\n Running tests/bindings-ubm.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/bindings_ubm-d956fe63499e364b)\n Running unittests src/subplot.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot-6e2d40b85612c9de)\n Running tests/seq.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/seq-8f189b8969864ac7)\n Running unittests src/lib.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplotlib-4fef6eb454a800fb)\n Running tests/files.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/files-46b83a9fe1a10943)\n Running tests/runcmd.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/runcmd-89549dd3dbb5a7dc)\n Running tests/subplot-codegen.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_codegen-60013b2c5f6419cd)\n Running tests/subplot-diagrams.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_diagrams-93cb505d641ffc94)\n Running tests/subplot-docgen.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_docgen-a4cfeaf1354d946c)\n Running tests/subplot-extract.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_extract-27a75e023100fade)\n Running tests/subplot-metadata.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_metadata-eb5c74dfad67504e)\n Running tests/subplot-others.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplot_others-1ce247a5de7a973c)\n Running tests/subplotlib.rs (/ci/cache/cargo-target/x86_64-unknown-linux-musl/debug/deps/subplotlib-2d3b35de1a9808f6)\n Running unittests src/lib.rs (/ci/cache/cargo-target/debug/deps/subplotlib_derive-9fc045209741d6bd)\n Doc-tests subplot\n Doc-tests subplotlib\n Doc-tests subplotlib_derive\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n Compiling zerocopy v0.8.31\n Compiling serde_core v1.0.228\n Compiling crossbeam-utils v0.8.21\n Compiling ahash v0.8.12\n Compiling serde v1.0.228\n Compiling regex-automata v0.4.13\n Compiling libc v0.2.178\n Compiling encoding_rs v0.8.35\n Compiling doc-comment v0.3.4\n Compiling anyhow v1.0.100\n Compiling crossbeam-epoch v0.9.18\n Compiling hashbrown v0.14.5\n Compiling getrandom v0.2.16\n Compiling globset v0.4.18\n Compiling hashlink v0.9.1\n Compiling rustix v1.1.2\n Compiling libm v0.2.15\n Compiling rand_core v0.6.4\n Compiling crossbeam-deque v0.8.6\n Compiling serde_path_to_error v0.1.20\n Compiling ppv-lite86 v0.2.21\n Compiling serde_json v1.0.145\n Compiling thiserror v2.0.17\n Compiling rand_chacha v0.3.1\n Compiling ignore v0.4.25\n Compiling yaml-rust2 v0.9.0\n Compiling getrandom v0.3.4\n Compiling marked-yaml v0.7.2\n Compiling pulldown-cmark v0.13.0\n Compiling tempfile v3.23.0\n Compiling pikchr v0.1.4\n Compiling humansize v2.1.3\n Compiling globwalk v0.9.1\n Compiling yaml-rust2 v0.10.4\n Compiling rand v0.8.5\n Compiling subplot v0.14.0 (/ci/src)\n Compiling regex v1.12.2\n Compiling memchr v2.7.6\n Compiling tera v1.20.1\n Compiling aho-corasick v1.1.4\n Compiling nix v0.29.0\n Compiling marked-yaml v0.8.0\n Compiling roadmap v0.7.0\n Compiling cvt v0.1.2\n Compiling time-macros v0.2.24\n Compiling fs_at v0.2.1\n Compiling culpa v1.0.2\n Compiling normpath v1.5.0\n Compiling subplotlib v0.14.0 (/ci/src/subplotlib)\n Compiling once_cell v1.21.3\n Compiling remove_dir_all v1.0.0\n Compiling subplotlib-derive v0.14.0 (/ci/src/subplotlib-derive)\n Compiling time v0.3.44\n Compiling fs2 v0.4.3\n Compiling filetime v0.2.26\n Compiling state v0.6.0\n Compiling shell-words v1.1.1\n Compiling subplot-seq-example v0.1.0 (/ci/src/examples/seq)\n Finished `test` profile [unoptimized + debuginfo] target(s) in 16.73s\n Running tests/seq.rs (/ci/cache/cargo-target/debug/deps/seq-73545bb4a9dac185)\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n INFO Starting Subplot\n INFO Subplot finished successfully\n+ cp -a doc/files.html doc/libdocs doc/muck.html doc/runcmd.html doc/seq.html doc/subplot.html doc/user-guide.html doc/website.html /ci/artifacts/.\n+ git reset --hard\n+ git clean -fdx\n+ git status --ignored\n",
"timestamp": {
"secs_since_epoch": 1774034957,
"nanos_since_epoch": 237094121
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "make OFFLINE=\"--offline\"\ncp -a doc/* /ci/artifacts/.\n\n# Clean up after tests and documentation building.\ngit reset --hard\ngit clean -fdx\ngit status --ignored\n",
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 126977097
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "custom",
"name": "dch",
"args": {
"debfullname": "Lars Wirzenius",
"debemail": "liw@liw.fi"
},
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 127102707
},
"log_source": "Plan"
}{
"type": "custom_action_starts",
"source": "/ci/src",
"custom": {
"name": "dch",
"args": {
"debemail": "liw@liw.fi",
"debfullname": "Lars Wirzenius"
}
},
"exe": ".ambient/dch",
"exe_exists": false,
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 127122300
},
"log_source": "Plan"
}{
"type": "custom_action_output",
"stdout": [
72,
69,
65,
68,
32,
105,
115,
32,
110,
111,
119,
32,
97,
116,
32,
99,
102,
101,
98,
102,
99,
57,
32,
77,
101,
114,
103,
101,
32,
98,
114,
97,
110,
99,
104,
32,
39,
102,
105,
120,
45,
99,
105,
39,
32,
105,
110,
116,
111,
32,
39,
109,
97,
105,
110,
39,
10
],
"stderr": [
43,
32,
101,
120,
112,
111,
114,
116,
32,
39,
68,
69,
66,
69,
77,
65,
73,
76,
61,
34,
108,
105,
119,
64,
108,
105,
119,
46,
102,
105,
34,
39,
10,
43,
32,
68,
69,
66,
69,
77,
65,
73,
76,
61,
39,
34,
108,
105,
119,
64,
108,
105,
119,
46,
102,
105,
34,
39,
10,
43,
32,
101,
120,
112,
111,
114,
116,
32,
39,
68,
69,
66,
70,
85,
76,
76,
78,
65,
77,
69,
61,
34,
76,
97,
114,
115,
32,
87,
105,
114,
122,
101,
110,
105,
117,
115,
34,
39,
10,
43,
32,
68,
69,
66,
70,
85,
76,
76,
78,
65,
77,
69,
61,
39,
34,
76,
97,
114,
115,
32,
87,
105,
114,
122,
101,
110,
105,
117,
115,
34,
39,
10,
43,
32,
101,
120,
112,
111,
114,
116,
32,
67,
65,
82,
71,
79,
95,
84,
65,
82,
71,
69,
84,
95,
68,
73,
82,
61,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
47,
99,
97,
99,
104,
101,
10,
43,
32,
67,
65,
82,
71,
79,
95,
84,
65,
82,
71,
69,
84,
95,
68,
73,
82,
61,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
47,
99,
97,
99,
104,
101,
10,
43,
32,
101,
120,
112,
111,
114,
116,
32,
67,
65,
82,
71,
79,
95,
72,
79,
77,
69,
61,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
47,
100,
101,
112,
115,
10,
43,
32,
67,
65,
82,
71,
79,
95,
72,
79,
77,
69,
61,
47,
119,
111,
114,
107,
115,
112,
97,
99,
101,
47,
100,
101,
112,
115,
10,
43,
32,
101,
120,
112,
111,
114,
116,
32,
72,
79,
77,
69,
61,
47,
114,
111,
111,
116,
10,
43,
32,
72,
79,
77,
69,
61,
47,
114,
111,
111,
116,
10,
43,
32,
101,
120,
112,
111,
114,
116,
32,
80,
65,
84,
72,
61,
47,
114,
111,
111,
116,
47,
46,
99,
97,
114,
103,
111,
47,
98,
105,
110,
58,
47,
114,
111,
111,
116,
47,
46,
99,
97,
114,
103,
111,
47,
98,
105,
110,
58,
47,
117,
115,
114,
47,
108,
111,
99,
97,
108,
47,
115,
98,
105,
110,
58,
47,
117,
115,
114,
47,
108,
111,
99,
97,
108,
47,
98,
105,
110,
58,
47,
117,
115,
114,
47,
115,
98,
105,
110,
58,
47,
117,
115,
114,
47,
98,
105,
110,
58,
47,
115,
98,
105,
110,
58,
47,
98,
105,
110,
10,
43,
32,
80,
65,
84,
72,
61,
47,
114,
111,
111,
116,
47,
46,
99,
97,
114,
103,
111,
47,
98,
105,
110,
58,
47,
114,
111,
111,
116,
47,
46,
99,
97,
114,
103,
111,
47,
98,
105,
110,
58,
47,
117,
115,
114,
47,
108,
111,
99,
97,
108,
47,
115,
98,
105,
110,
58,
47,
117,
115,
114,
47,
108,
111,
99,
97,
108,
47,
98,
105,
110,
58,
47,
117,
115,
114,
47,
115,
98,
105,
110,
58,
47,
117,
115,
114,
47,
98,
105,
110,
58,
47,
115,
98,
105,
110,
58,
47,
98,
105,
110,
10,
43,
32,
103,
105,
116,
32,
114,
101,
115,
101,
116,
32,
45,
45,
104,
97,
114,
100,
10,
43,
32,
103,
105,
116,
32,
99,
108,
101,
97,
110,
32,
45,
102,
100,
120,
10,
43,
43,
32,
100,
112,
107,
103,
45,
112,
97,
114,
115,
101,
99,
104,
97,
110,
103,
101,
108,
111,
103,
32,
45,
83,
86,
101,
114,
115,
105,
111,
110,
10,
43,
43,
32,
115,
101,
100,
32,
39,
115,
47,
45,
91,
94,
45,
93,
42,
36,
47,
47,
39,
10,
43,
32,
86,
61,
48,
46,
49,
52,
46,
48,
10,
43,
43,
32,
100,
97,
116,
101,
32,
45,
117,
32,
43,
37,
89,
37,
109,
37,
100,
84,
37,
72,
37,
77,
37,
83,
10,
43,
32,
84,
61,
50,
48,
50,
54,
48,
51,
50,
48,
84,
49,
57,
50,
57,
49,
56,
10,
43,
32,
118,
101,
114,
115,
105,
111,
110,
61,
48,
46,
49,
52,
46,
48,
46,
99,
105,
50,
48,
50,
54,
48,
51,
50,
48,
84,
49,
57,
50,
57,
49,
56,
45,
49,
10,
43,
32,
100,
99,
104,
32,
45,
118,
32,
48,
46,
49,
52,
46,
48,
46,
99,
105,
50,
48,
50,
54,
48,
51,
50,
48,
84,
49,
57,
50,
57,
49,
56,
45,
49,
32,
39,
67,
73,
32,
98,
117,
105,
108,
100,
32,
117,
110,
100,
101,
114,
32,
65,
109,
98,
105,
101,
110,
116,
46,
39,
10,
43,
32,
100,
99,
104,
32,
45,
114,
32,
39,
39,
10
],
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 373653723
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "custom",
"name": "dch",
"args": {
"debemail": "liw@liw.fi",
"debfullname": "Lars Wirzenius"
},
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 373909885
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "deb",
"packages": ".",
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 374102558
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
47,
98,
105,
110,
47,
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
35,
33,
47,
117,
115,
114,
47,
98,
105,
110,
47,
101,
110,
118,
32,
98,
97,
115,
104,
10,
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
10,
101,
99,
104,
111,
32,
34,
80,
65,
84,
72,
32,
97,
116,
32,
115,
116,
97,
114,
116,
58,
32,
36,
80,
65,
84,
72,
34,
10,
101,
120,
112,
111,
114,
116,
32,
80,
65,
84,
72,
61,
34,
47,
114,
111,
111,
116,
47,
46,
99,
97,
114,
103,
111,
47,
98,
105,
110,
58,
36,
80,
65,
84,
72,
34,
10,
101,
120,
112,
111,
114,
116,
32,
67,
65,
82,
71,
79,
95,
72,
79,
77,
69,
61,
47,
99,
105,
47,
100,
101,
112,
115,
10,
101,
120,
112,
111,
114,
116,
32,
68,
69,
66,
69,
77,
65,
73,
76,
61,
108,
105,
119,
64,
108,
105,
119,
46,
102,
105,
10,
101,
120,
112,
111,
114,
116,
32,
68,
69,
66,
70,
85,
76,
76,
78,
65,
77,
69,
61,
34,
76,
97,
114,
115,
32,
87,
105,
114,
122,
101,
110,
105,
117,
115,
34,
10,
47,
98,
105,
110,
47,
101,
110,
118,
10,
10,
99,
111,
109,
109,
97,
110,
100,
32,
45,
118,
32,
99,
97,
114,
103,
111,
10,
99,
111,
109,
109,
97,
110,
100,
32,
45,
118,
32,
114,
117,
115,
116,
99,
10,
10,
99,
97,
114,
103,
111,
32,
45,
45,
118,
101,
114,
115,
105,
111,
110,
10,
114,
117,
115,
116,
99,
32,
45,
45,
118,
101,
114,
115,
105,
111,
110,
10,
10,
35,
32,
71,
101,
116,
32,
110,
97,
109,
101,
32,
97,
110,
100,
32,
118,
101,
114,
115,
105,
111,
110,
32,
111,
102,
32,
115,
111,
117,
114,
99,
101,
32,
112,
97,
99,
107,
97,
103,
101,
46,
10,
110,
97,
109,
101,
61,
34,
36,
40,
100,
112,
107,
103,
45,
112,
97,
114,
115,
101,
99,
104,
97,
110,
103,
101,
108,
111,
103,
32,
45,
83,
83,
111,
117,
114,
99,
101,
41,
34,
10,
118,
101,
114,
115,
105,
111,
110,
61,
34,
36,
40,
100,
112,
107,
103,
45,
112,
97,
114,
115,
101,
99,
104,
97,
110,
103,
101,
108,
111,
103,
32,
45,
83,
86,
101,
114,
115,
105,
111,
110,
41,
34,
10,
10,
35,
32,
71,
101,
116,
32,
117,
112,
115,
116,
114,
101,
97,
109,
32,
118,
101,
114,
115,
105,
111,
110,
58,
32,
101,
118,
101,
114,
121,
116,
104,
105,
110,
103,
32,
98,
101,
102,
111,
114,
101,
32,
116,
104,
101,
32,
108,
97,
115,
116,
32,
100,
97,
115,
104,
46,
10,
117,
118,
61,
34,
36,
40,
101,
99,
104,
111,
32,
34,
36,
118,
101,
114,
115,
105,
111,
110,
34,
32,
124,
32,
115,
101,
100,
32,
39,
115,
47,
45,
91,
94,
45,
93,
42,
36,
47,
47,
39,
41,
34,
10,
10,
35,
32,
70,
105,
108,
101,
115,
32,
116,
104,
97,
116,
32,
119,
105,
108,
108,
32,
98,
101,
32,
99,
114,
101,
97,
116,
101,
100,
46,
10,
97,
114,
99,
104,
61,
34,
36,
40,
100,
112,
107,
103,
32,
45,
45,
112,
114,
105,
110,
116,
45,
97,
114,
99,
104,
105,
116,
101,
99,
116,
117,
114,
101,
41,
34,
10,
111,
114,
105,
103,
61,
34,
46,
46,
47,
36,
123,
110,
97,
109,
101,
125,
95,
36,
123,
117,
118,
125,
46,
111,
114,
105,
103,
46,
116,
97,
114,
46,
120,
122,
34,
10,
100,
101,
98,
61,
34,
46,
46,
47,
36,
123,
110,
97,
109,
101,
125,
95,
36,
123,
118,
101,
114,
115,
105,
111,
110,
125,
95,
36,
123,
97,
114,
99,
104,
125,
46,
100,
101,
98,
34,
10,
99,
104,
97,
110,
103,
101,
115,
61,
34,
46,
46,
47,
36,
123,
110,
97,
109,
101,
125,
95,
36,
123,
118,
101,
114,
115,
105,
111,
110,
125,
95,
36,
123,
97,
114,
99,
104,
125,
46,
99,
104,
97,
110,
103,
101,
115,
34,
10,
10,
35,
32,
67,
114,
101,
97,
116,
101,
32,
34,
117,
112,
115,
116,
114,
101,
97,
109,
32,
116,
97,
114,
98,
97,
108,
108,
34,
46,
10,
103,
105,
116,
32,
97,
114,
99,
104,
105,
118,
101,
32,
72,
69,
65,
68,
32,
124,
32,
120,
122,
32,
62,
34,
36,
111,
114,
105,
103,
34,
10,
10,
35,
32,
66,
117,
105,
108,
100,
32,
112,
97,
99,
107,
97,
103,
101,
46,
10,
100,
112,
107,
103,
45,
98,
117,
105,
108,
100,
112,
97,
99,
107,
97,
103,
101,
32,
45,
117,
115,
32,
45,
117,
99,
10,
10,
35,
32,
68,
117,
109,
112,
32,
115,
111,
109,
101,
32,
105,
110,
102,
111,
114,
109,
97,
116,
105,
111,
110,
32,
116,
111,
32,
109,
97,
107,
101,
32,
105,
116,
32,
101,
97,
115,
105,
101,
114,
32,
116,
111,
32,
118,
105,
115,
117,
97,
108,
108,
121,
32,
118,
101,
114,
105,
102,
121,
10,
35,
32,
101,
118,
101,
114,
121,
116,
104,
105,
110,
103,
32,
108,
111,
111,
107,
115,
32,
79,
75,
46,
32,
65,
108,
115,
111,
44,
32,
116,
101,
115,
116,
32,
116,
104,
101,
32,
112,
97,
99,
107,
97,
103,
101,
32,
119,
105,
116,
104,
32,
116,
104,
101,
32,
108,
105,
110,
116,
105,
97,
110,
32,
116,
111,
111,
108,
46,
10,
10,
108,
115,
32,
45,
108,
32,
46,
46,
10,
102,
111,
114,
32,
120,
32,
105,
110,
32,
46,
46,
47,
42,
46,
100,
101,
98,
59,
32,
100,
111,
32,
100,
112,
107,
103,
32,
45,
99,
32,
34,
36,
120,
34,
59,
32,
100,
111,
110,
101,
10,
35,
32,
70,
73,
88,
77,
69,
58,
32,
100,
105,
115,
97,
98,
108,
101,
100,
32,
119,
104,
105,
108,
101,
32,
116,
104,
105,
115,
32,
112,
114,
101,
118,
101,
110,
116,
115,
32,
114,
97,
100,
105,
99,
108,
101,
45,
110,
97,
116,
105,
118,
101,
45,
99,
105,
32,
100,
101,
98,
32,
102,
114,
111,
109,
32,
98,
101,
105,
110,
103,
32,
98,
117,
105,
108,
116,
46,
10,
35,
32,
108,
105,
110,
116,
105,
97,
110,
32,
45,
105,
32,
45,
45,
97,
108,
108,
111,
119,
45,
114,
111,
111,
116,
32,
45,
45,
102,
97,
105,
108,
45,
111,
110,
32,
119,
97,
114,
110,
105,
110,
103,
32,
46,
46,
47,
42,
46,
99,
104,
97,
110,
103,
101,
115,
10,
10,
35,
32,
77,
111,
118,
101,
32,
102,
105,
108,
101,
115,
32,
116,
111,
32,
97,
114,
116,
105,
102,
97,
99,
116,
115,
32,
100,
105,
114,
101,
99,
116,
111,
114,
121,
46,
10,
109,
118,
32,
46,
46,
47,
42,
95,
42,
32,
47,
99,
105,
47,
97,
114,
116,
105,
102,
97,
99,
116,
115,
47,
46,
10,
32,
32,
32,
32,
32,
32,
32,
32
]
}
],
"timestamp": {
"secs_since_epoch": 1774034958,
"nanos_since_epoch": 374120937
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "PATH at start: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\nDEBFULLNAME=Lars Wirzenius\nCARGO_TARGET_DIR=/ci/cache/cargo-target\nPWD=/ci/src\nSYSTEMD_EXEC_PID=283\nHOME=/root\nLANG=C.UTF-8\nCARGO_HOME=/ci/deps\nDEBEMAIL=liw@liw.fi\nINVOCATION_ID=68d09a8db75f4ee4b82549facfc80457\nSHLVL=2\nJOURNAL_STREAM=8:15092\nPATH=/root/.cargo/bin:/root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\nOLDPWD=/\n_=/bin/env\n/root/.cargo/bin/cargo\n/root/.cargo/bin/rustc\ncargo 1.94.0 (85eff7c80 2026-01-15)\nrustc 1.94.0 (4a4ef493e 2026-03-02)\ndpkg-buildpackage: info: source package subplot\ndpkg-buildpackage: info: source version 0.14.0.ci20260320T192918-1\ndpkg-buildpackage: info: source distribution unstable\ndpkg-buildpackage: info: source changed by \"Lars Wirzenius\" <\"liw@liw.fi\">\ndpkg-buildpackage: info: host architecture amd64\ndh clean\n dh_auto_clean\n dh_clean\ndpkg-source: info: using source format '3.0 (quilt)'\ndpkg-source: info: building subplot using existing ./subplot_0.14.0.ci20260320T192918.orig.tar.xz\ndpkg-source: info: building subplot in subplot_0.14.0.ci20260320T192918-1.debian.tar.xz\ndpkg-source: info: building subplot in subplot_0.14.0.ci20260320T192918-1.dsc\ndh build\n dh_update_autotools_config\n dh_autoreconf\n dh_auto_configure\n debian/rules override_dh_auto_build\nmake[1]: Entering directory '/ci/src'\ntrue\nmake[1]: Leaving directory '/ci/src'\n debian/rules override_dh_auto_test\nmake[1]: Entering directory '/ci/src'\necho disabled\ndisabled\nmake[1]: Leaving directory '/ci/src'\n create-stamp debian/debhelper-build-stamp\ndh binary\n dh_testroot\n dh_prep\n debian/rules override_dh_auto_install\nmake[1]: Entering directory '/ci/src'\ncargo install --path=bin --root=debian/subplot --offline --locked --target x86_64-unknown-linux-musl\nrm -f debian/subplot/.crates.toml\nrm -f debian/subplot/.crates2.json\ndh_lintian\nmake[1]: Leaving directory '/ci/src'\n dh_install\n dh_installdocs\n dh_installchangelogs\n dh_lintian\n dh_perl\n dh_link\n dh_strip_nondeterminism\n dh_compress\n dh_fixperms\n dh_missing\n dh_strip\n dh_makeshlibs\n dh_shlibdeps\n dh_installdeb\n dh_gencontrol\n dh_md5sums\n dh_builddeb\ndpkg-deb: building package 'subplot-dbgsym' in '../subplot-dbgsym_0.14.0.ci20260320T192918-1_amd64.deb'.\ndpkg-deb: building package 'subplot' in '../subplot_0.14.0.ci20260320T192918-1_amd64.deb'.\ndpkg-genchanges: info: including full source code in upload\ndpkg-buildpackage: info: full upload (original source is included)\ntotal 2300\ndrwxr-xr-x 3 root root 4096 Mar 20 19:29 artifacts\ndrwxr-xr-x 3 root root 4096 Mar 20 19:26 cache\ndrwxr-xr-x 3 root root 4096 Mar 20 19:26 deps\ndrwxr-xr-x 15 root root 4096 Mar 20 19:29 src\n-rw-r--r-- 1 root root 239436 Mar 20 19:30 subplot-dbgsym_0.14.0.ci20260320T192918-1_amd64.deb\n-rw-r--r-- 1 root root 2436 Mar 20 19:29 subplot_0.14.0.ci20260320T192918-1.debian.tar.xz\n-rw-r--r-- 1 root root 1018 Mar 20 19:29 subplot_0.14.0.ci20260320T192918-1.dsc\n-rw-r--r-- 1 root root 10199 Mar 20 19:30 subplot_0.14.0.ci20260320T192918-1_amd64.buildinfo\n-rw-r--r-- 1 root root 2392 Mar 20 19:30 subplot_0.14.0.ci20260320T192918-1_amd64.changes\n-rw-r--r-- 1 root root 1920388 Mar 20 19:30 subplot_0.14.0.ci20260320T192918-1_amd64.deb\n-rw-r--r-- 1 root root 148912 Mar 20 19:29 subplot_0.14.0.ci20260320T192918.orig.tar.xz\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/lib/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/lib/debug/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/lib/debug/.build-id/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/lib/debug/.build-id/88/\n-rw-r--r-- root/root 1455704 2026-03-20 19:29 ./usr/lib/debug/.build-id/88/1135dd1827d23c73bde0b00e1afd235bc57f27.debug\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/doc/\nlrwxrwxrwx root/root 0 2026-03-20 19:29 ./usr/share/doc/subplot-dbgsym -> subplot\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./bin/\n-rwxr-xr-x root/root 7184184 2026-03-20 19:29 ./bin/subplot\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/doc/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/doc/subplot/\n-rw-r--r-- root/root 3623 2026-03-20 19:26 ./usr/share/doc/subplot/README.md\n-rw-r--r-- root/root 670 2026-03-20 19:29 ./usr/share/doc/subplot/changelog.Debian.gz\n-rw-r--r-- root/root 1394 2026-03-20 19:26 ./usr/share/doc/subplot/copyright\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/lintian/\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/lintian/overrides/\n-rw-r--r-- root/root 103 2026-03-20 19:26 ./usr/share/lintian/overrides/subplot\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/subplot/\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/common/\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/common/lib/\n-rw-r--r-- root/root 10532 2026-03-20 19:26 ./usr/share/subplot/common/lib/files.yaml\n-rw-r--r-- root/root 8784 2026-03-20 19:26 ./usr/share/subplot/common/lib/runcmd.yaml\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/python/\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/python/lib/\n-rw-r--r-- root/root 10415 2026-03-20 19:26 ./usr/share/subplot/python/lib/daemon.py\n-rw-r--r-- root/root 4434 2026-03-20 19:26 ./usr/share/subplot/python/lib/daemon.yaml\n-rw-r--r-- root/root 8048 2026-03-20 19:26 ./usr/share/subplot/python/lib/files.py\n-rw-r--r-- root/root 8657 2026-03-20 19:26 ./usr/share/subplot/python/lib/runcmd.py\ndrwxr-xr-x root/root 0 2026-03-20 19:29 ./usr/share/subplot/python/template/\n-rw-r--r-- root/root 1275 2026-03-20 19:26 ./usr/share/subplot/python/template/asserts.py\n-rw-r--r-- root/root 2457 2026-03-20 19:26 ./usr/share/subplot/python/template/context.py\n-rw-r--r-- root/root 4611 2026-03-20 19:26 ./usr/share/subplot/python/template/context_tests.py\n-rw-r--r-- root/root 201 2026-03-20 19:26 ./usr/share/subplot/python/template/encoding.py\n-rw-r--r-- root/root 474 2026-03-20 19:26 ./usr/share/subplot/python/template/encoding_tests.py\n-rw-r--r-- root/root 412 2026-03-20 19:26 ./usr/share/subplot/python/template/files.py\n-rw-r--r-- root/root 4821 2026-03-20 19:26 ./usr/share/subplot/python/template/main.py\n-rw-r--r-- root/root 2785 2026-03-20 19:26 ./usr/share/subplot/python/template/scenarios.py\n-rw-r--r-- root/root 2565 2026-03-20 19:26 ./usr/share/subplot/python/template/template.py.tera\n-rw-r--r-- root/root 137 2026-03-20 19:26 ./usr/share/subplot/python/template/template.yaml\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/rust/\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/rust/lib/\n-rw-r--r-- root/root 788 2026-03-20 19:26 ./usr/share/subplot/rust/lib/datadir.yaml\ndrwxr-xr-x root/root 0 2026-03-20 19:26 ./usr/share/subplot/rust/template/\n-rw-r--r-- root/root 1449 2026-03-20 19:26 ./usr/share/subplot/rust/template/macros.rs.tera\n-rw-r--r-- root/root 1213 2026-03-20 19:26 ./usr/share/subplot/rust/template/template.rs.tera\n-rw-r--r-- root/root 71 2026-03-20 19:26 ./usr/share/subplot/rust/template/template.yaml\n-rw-r--r-- root/root 2103 2026-03-20 19:26 ./usr/share/subplot/subplot.css\n",
"stderr": "+ echo 'PATH at start: /root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin'\n+ export PATH=/root/.cargo/bin:/root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\n+ PATH=/root/.cargo/bin:/root/.cargo/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\n+ export CARGO_HOME=/ci/deps\n+ CARGO_HOME=/ci/deps\n+ export DEBEMAIL=liw@liw.fi\n+ DEBEMAIL=liw@liw.fi\n+ export 'DEBFULLNAME=Lars Wirzenius'\n+ DEBFULLNAME='Lars Wirzenius'\n+ /bin/env\n+ command -v cargo\n+ command -v rustc\n+ cargo --version\n+ rustc --version\n++ dpkg-parsechangelog -SSource\n+ name=subplot\n++ dpkg-parsechangelog -SVersion\n+ version=0.14.0.ci20260320T192918-1\n++ echo 0.14.0.ci20260320T192918-1\n++ sed 's/-[^-]*$//'\n+ uv=0.14.0.ci20260320T192918\n++ dpkg --print-architecture\n+ arch=amd64\n+ orig=../subplot_0.14.0.ci20260320T192918.orig.tar.xz\n+ deb=../subplot_0.14.0.ci20260320T192918-1_amd64.deb\n+ changes=../subplot_0.14.0.ci20260320T192918-1_amd64.changes\n+ git archive HEAD\n+ xz\n+ dpkg-buildpackage -us -uc\n dpkg-source --before-build .\n debian/rules clean\n dpkg-source -b .\n debian/rules build\n debian/rules binary\n Installing subplot-bin v0.14.0 (/ci/src/bin)\n Compiling proc-macro2 v1.0.103\n Compiling unicode-ident v1.0.22\n Compiling quote v1.0.42\n Compiling cfg-if v1.0.4\n Compiling memchr v2.7.6\n Compiling syn v2.0.111\n Compiling zerocopy v0.8.31\n Compiling once_cell v1.21.3\n Compiling libc v0.2.178\n Compiling serde_core v1.0.228\n Compiling aho-corasick v1.1.4\n Compiling regex-syntax v0.8.8\n Compiling version_check v0.9.5\n Compiling ahash v0.8.12\n Compiling regex-automata v0.4.13\n Compiling itoa v1.0.15\n Compiling crossbeam-utils v0.8.21\n Compiling anyhow v1.0.100\n Compiling bitflags v2.10.0\n Compiling log v0.4.29\n Compiling serde v1.0.228\n Compiling serde_derive v1.0.228\n Compiling encoding_rs v0.8.35\n Compiling ucd-trie v0.1.7\n Compiling doc-comment v0.3.4\n Compiling arraydeque v0.5.1\n Compiling pest v2.8.4\n Compiling crossbeam-epoch v0.9.18\n Compiling hashbrown v0.14.5\n Compiling getrandom v0.2.16\n Compiling bstr v1.12.1\n Compiling shlex v1.3.0\n Compiling same-file v1.0.6\n Compiling utf8parse v0.2.2\n Compiling unicode-width v0.2.2\n Compiling find-msvc-tools v0.1.5\n Compiling getrandom v0.3.4\n Compiling foldhash v0.1.5\n Compiling time-core v0.1.6\n Compiling libm v0.2.15\n Compiling num-conv v0.1.0\n Compiling rustix v1.1.2\n Compiling time-macros v0.2.24\n Compiling hashbrown v0.15.5\n Compiling cc v1.2.49\n Compiling globset v0.4.18\n Compiling anstyle-parse v0.2.7\n Compiling walkdir v2.5.0\n Compiling hashlink v0.9.1\n Compiling rand_core v0.6.4\n Compiling crossbeam-deque v0.8.6\n Compiling pest_meta v2.8.4\n Compiling serde_path_to_error v0.1.20\n Compiling ppv-lite86 v0.2.21\n Compiling tracing-core v0.1.36\n Compiling colorchoice v1.0.4\n Compiling thiserror v2.0.17\n Compiling serde_json v1.0.145\n Compiling linux-raw-sys v0.11.0\n Compiling powerfmt v0.2.0\n Compiling lazy_static v1.5.0\n Compiling anstyle-query v1.1.5\n Compiling anstyle v1.0.13\n Compiling is_terminal_polyfill v1.70.2\n Compiling anstream v0.6.21\n Compiling deranged v0.5.5\n Compiling rand_chacha v0.3.1\n Compiling pest_generator v2.8.4\n Compiling ignore v0.4.25\n Compiling yaml-rust2 v0.9.0\n Compiling pikchr v0.1.4\n Compiling hashlink v0.10.0\n Compiling thiserror-impl v2.0.17\n Compiling tracing-attributes v0.1.31\n Compiling pin-project-lite v0.2.16\n Compiling deunicode v1.6.2\n Compiling heck v0.5.0\n Compiling strsim v0.11.1\n Compiling ryu v1.0.20\n Compiling fastrand v2.3.0\n Compiling clap_lex v0.7.6\n Compiling pulldown-cmark v0.13.0\n Compiling smawk v0.3.2\n Compiling unicode-linebreak v0.1.5\n Compiling textwrap v0.16.2\n Compiling clap_builder v4.5.53\n Compiling tempfile v3.23.0\n Compiling tracing v0.1.44\n Compiling clap_derive v4.5.49\n Compiling slug v0.1.6\n Compiling time v0.3.44\n Compiling humansize v2.1.3\n Compiling yaml-rust2 v0.10.4\n Compiling marked-yaml v0.7.2\n Compiling globwalk v0.9.1\n Compiling pest_derive v2.8.4\n Compiling subplot v0.14.0 (/ci/src)\n Compiling rand v0.8.5\n Compiling getopts v0.2.24\n Compiling regex v1.12.2\n Compiling unicase v2.8.1\n Compiling pulldown-cmark-escape v0.11.0\n Compiling percent-encoding v2.3.2\n Compiling utf8-width v0.1.8\n Compiling unicode-segmentation v1.12.0\n Compiling tera v1.20.1\n Compiling html-escape v0.2.13\n Compiling git-testament-derive v0.2.1\n Compiling roadmap v0.7.0\n Compiling marked-yaml v0.8.0\n Compiling clap v4.5.53\n Compiling sharded-slab v0.1.7\n Compiling tracing-log v0.2.0\n Compiling matchers v0.2.0\n Compiling thread_local v1.1.9\n Compiling nu-ansi-term v0.50.3\n Compiling line-col v0.2.1\n Compiling smallvec v1.15.1\n Compiling descape v3.0.0\n Compiling base64 v0.22.1\n Compiling tracing-subscriber v0.3.22\n Compiling git-testament v0.2.6\n Compiling subplot-bin v0.14.0 (/ci/src/bin)\n Finished `release` profile [optimized] target(s) in 1m 12s\n Installing /ci/src/debian/subplot/bin/subplot\n Installed package `subplot-bin v0.14.0 (/ci/src/bin)` (executable `subplot`)\nwarning: be sure to add `/ci/src/debian/subplot/bin` to your PATH to be able to run the installed binaries\ndh_installchangelogs: warning: Could not parse timestamp '15 April 2022 15:00:00 +0100'. debian/changelog will not be trimmed.\ndh_installchangelogs: warning: debian/changelog could not be trimmed. The full changelog will be installed.\ndpkg-shlibdeps: warning: couldn't parse dynamic symbol definition: no symbols\ndpkg-gencontrol: warning: Depends field of package subplot: substitution variable ${shlibs:Depends} used, but is not defined\ndpkg-gencontrol: warning: Built-Using field of package subplot: substitution variable ${cargo:Built-Using} used, but is not defined\ndpkg-gencontrol: warning: Depends field of package subplot: substitution variable ${shlibs:Depends} used, but is not defined\ndpkg-gencontrol: warning: Built-Using field of package subplot: substitution variable ${cargo:Built-Using} used, but is not defined\n dpkg-genbuildinfo -O../subplot_0.14.0.ci20260320T192918-1_amd64.buildinfo\n dpkg-genchanges -O../subplot_0.14.0.ci20260320T192918-1_amd64.changes\n dpkg-source --after-build .\n+ ls -l ..\n+ for x in ../*.deb\n+ dpkg -c ../subplot-dbgsym_0.14.0.ci20260320T192918-1_amd64.deb\n+ for x in ../*.deb\n+ dpkg -c ../subplot_0.14.0.ci20260320T192918-1_amd64.deb\n+ mv ../subplot-dbgsym_0.14.0.ci20260320T192918-1_amd64.deb ../subplot_0.14.0.ci20260320T192918-1.debian.tar.xz ../subplot_0.14.0.ci20260320T192918-1.dsc ../subplot_0.14.0.ci20260320T192918-1_amd64.buildinfo ../subplot_0.14.0.ci20260320T192918-1_amd64.changes ../subplot_0.14.0.ci20260320T192918-1_amd64.deb ../subplot_0.14.0.ci20260320T192918.orig.tar.xz /ci/artifacts/.\n",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 355365427
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "deb",
"packages": ".",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 511647581
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "shell",
"shell": "find /ci/artifacts\n",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 511805428
},
"log_source": "Plan"
}{
"type": "start_program",
"argv": [
{
"Unix": [
98,
97,
115,
104
]
},
{
"Unix": [
45,
99
]
},
{
"Unix": [
115,
101,
116,
32,
45,
120,
101,
117,
111,
32,
112,
105,
112,
101,
102,
97,
105,
108,
10,
102,
105,
110,
100,
32,
47,
99,
105,
47,
97,
114,
116,
105,
102,
97,
99,
116,
115,
10,
10
]
}
],
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 511826848
},
"log_source": "Plan"
}{
"type": "program_succeeded",
"exit_code": 0,
"stdout": "/ci/artifacts\n/ci/artifacts/muck.html\n/ci/artifacts/runcmd.html\n/ci/artifacts/subplot_0.14.0.ci20260320T192918-1_amd64.changes\n/ci/artifacts/subplot-dbgsym_0.14.0.ci20260320T192918-1_amd64.deb\n/ci/artifacts/files.html\n/ci/artifacts/website.html\n/ci/artifacts/seq.html\n/ci/artifacts/user-guide.html\n/ci/artifacts/libdocs\n/ci/artifacts/libdocs/daemon.html\n/ci/artifacts/libdocs/runcmd.html\n/ci/artifacts/libdocs/files.html\n/ci/artifacts/subplot_0.14.0.ci20260320T192918-1.dsc\n/ci/artifacts/subplot_0.14.0.ci20260320T192918-1.debian.tar.xz\n/ci/artifacts/subplot.html\n/ci/artifacts/subplot_0.14.0.ci20260320T192918-1_amd64.deb\n/ci/artifacts/subplot_0.14.0.ci20260320T192918-1_amd64.buildinfo\n/ci/artifacts/subplot_0.14.0.ci20260320T192918.orig.tar.xz\n",
"stderr": "+ find /ci/artifacts\n",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 567917840
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "shell",
"shell": "find /ci/artifacts\n",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 567943836
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_create",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1774035035,
"nanos_since_epoch": 567948875
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_create",
"archive": "/dev/vde",
"directory": "/ci/cache",
"timestamp": {
"secs_since_epoch": 1774035039,
"nanos_since_epoch": 631630533
},
"log_source": "Plan"
}{
"type": "execute_action",
"action": "tar_create",
"archive": "/dev/vdd",
"directory": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1774035039,
"nanos_since_epoch": 634138449
},
"log_source": "Plan"
}{
"type": "action_succeeded",
"action": "tar_create",
"archive": "/dev/vdd",
"directory": "/ci/artifacts",
"timestamp": {
"secs_since_epoch": 1774035039,
"nanos_since_epoch": 642998416
},
"log_source": "Plan"
}{
"type": "plan_succeeded",
"timestamp": {
"secs_since_epoch": 1774035039,
"nanos_since_epoch": 645822794
},
"log_source": "Plan"
}{
"type": "executor_ends_successfully",
"timestamp": {
"secs_since_epoch": 1774035039,
"nanos_since_epoch": 648416916
},
"log_source": "Plan"
}{
"request": "trigger",
"version": 1,
"event_type": "push",
"repository": {
"id": "rad:zjxyd2A1A7FnxtC69qDfoAajfTHo",
"name": "subplot",
"description": "Capture and communicate acceptance criteria and their verification",
"private": false,
"default_branch": "main",
"delegates": [
"did:key:z6MkgEMYod7Hxfy9qCvDv5hYHkZ4ciWmLFgfvm3Wn1b2w2FV",
"did:key:z6MkkMqyfkMdn8p1LF7LbjjEPJmZGksr3cdpsvFdxKWUVfNZ"
]
},
"pusher": {
"id": "did:key:z6MkkMqyfkMdn8p1LF7LbjjEPJmZGksr3cdpsvFdxKWUVfNZ",
"alias": "kinnison-lassitude"
},
"before": "cfebfc90081c7b0e037f480a20db94910987b159",
"after": "cfebfc90081c7b0e037f480a20db94910987b159",
"branch": "main",
"commits": [
"cfebfc90081c7b0e037f480a20db94910987b159"
]
}run CI for rad:zjxyd2A1A7FnxtC69qDfoAajfTHo
<empty log>