rundoc 4.1.1 → 4.1.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +9 -0
- data/lib/rundoc/code_command/background/log/clear.rb +7 -2
- data/lib/rundoc/code_command/background/log/read.rb +7 -2
- data/lib/rundoc/code_command/background/start.rb +20 -12
- data/lib/rundoc/code_command/background/stdin_write.rb +8 -3
- data/lib/rundoc/code_command/background/stop.rb +8 -3
- data/lib/rundoc/code_command/background/wait.rb +7 -2
- data/lib/rundoc/code_command/website/navigate.rb +6 -2
- data/lib/rundoc/code_command/website/screenshot.rb +9 -4
- data/lib/rundoc/code_command/website/visit.rb +18 -11
- data/lib/rundoc/version.rb +1 -1
- data/test/integration/website_test.rb +2 -0
- data/test/rundoc/code_commands/background_test.rb +12 -3
- metadata +2 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: b65a04eca7d7099223b2a626c47eb78e14a8e102266cf880cddc747a0d9fc4a5
|
4
|
+
data.tar.gz: 840585e8f0c6b3cddbb1d15354f4fdf862d2440b20054cd1b5344c026adb23d9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 99661d14543918c21a988bd1c4cffc1d5c9d73a852a95c16b0905b5ddde312dc986d970b4082921752cd2eac4d786a0ae37f42f3577fdea2df54c6de50376810
|
7
|
+
data.tar.gz: 6819d3babc4cb2a7ad1f76386e3d7e7f28886a989e6a31ef052ea87b3b226a6979cc1c2092653fa7aadadd34d3f8af9b268464c2a14c70f385b559ee8a13ca9a
|
data/CHANGELOG.md
CHANGED
@@ -1,5 +1,14 @@
|
|
1
1
|
## HEAD
|
2
2
|
|
3
|
+
## 4.1.3
|
4
|
+
|
5
|
+
- Fix: Internal error in `background.wait` introduced in 4.1.2 (https://github.com/zombocom/rundoc/pull/97)
|
6
|
+
- Fix: Website commands such as `:::>> website.visit(...)` now use lazy lookup (like Background tasks since 4.1.2). This allows `pre.erb` to be used with these commands (https://github.com/zombocom/rundoc/pull/98)
|
7
|
+
|
8
|
+
## 4.1.2
|
9
|
+
|
10
|
+
- Fix: Background task name lookup is now lazy, this fixes a bug when using `:::>- pre.erb background.start(...)` (https://github.com/zombocom/rundoc/pull/95)
|
11
|
+
|
3
12
|
## 4.1.1
|
4
13
|
|
5
14
|
- Fix: Visibility forwarding for `pre.erb` was accidentally reversed, this is now fixed. (https://github.com/zombocom/rundoc/pull/93)
|
@@ -1,7 +1,12 @@
|
|
1
1
|
class Rundoc::CodeCommand::Background::Log
|
2
2
|
class Clear < Rundoc::CodeCommand
|
3
3
|
def initialize(name:)
|
4
|
-
@
|
4
|
+
@name = name
|
5
|
+
@background = nil
|
6
|
+
end
|
7
|
+
|
8
|
+
def background
|
9
|
+
@background ||= Rundoc::CodeCommand::Background::ProcessSpawn.find(@name)
|
5
10
|
end
|
6
11
|
|
7
12
|
def to_md(env = {})
|
@@ -9,7 +14,7 @@ class Rundoc::CodeCommand::Background::Log
|
|
9
14
|
end
|
10
15
|
|
11
16
|
def call(env = {})
|
12
|
-
|
17
|
+
background.log.truncate(0)
|
13
18
|
""
|
14
19
|
end
|
15
20
|
end
|
@@ -1,7 +1,12 @@
|
|
1
1
|
class Rundoc::CodeCommand::Background::Log
|
2
2
|
class Read < Rundoc::CodeCommand
|
3
3
|
def initialize(name:)
|
4
|
-
@
|
4
|
+
@name = name
|
5
|
+
@background = nil
|
6
|
+
end
|
7
|
+
|
8
|
+
def background
|
9
|
+
@background ||= Rundoc::CodeCommand::Background::ProcessSpawn.find(@name)
|
5
10
|
end
|
6
11
|
|
7
12
|
def to_md(env = {})
|
@@ -9,7 +14,7 @@ class Rundoc::CodeCommand::Background::Log
|
|
9
14
|
end
|
10
15
|
|
11
16
|
def call(env = {})
|
12
|
-
|
17
|
+
background.log.read
|
13
18
|
end
|
14
19
|
end
|
15
20
|
end
|
@@ -3,20 +3,28 @@ require "tempfile"
|
|
3
3
|
class Rundoc::CodeCommand::Background
|
4
4
|
class Start < Rundoc::CodeCommand
|
5
5
|
def initialize(command, name:, wait: nil, timeout: 5, log: Tempfile.new("log"), out: "2>&1", allow_fail: false)
|
6
|
+
@timeout = timeout
|
6
7
|
@command = command
|
7
8
|
@name = name
|
8
9
|
@wait = wait
|
9
10
|
@allow_fail = allow_fail
|
10
|
-
|
11
|
+
@log = log
|
12
|
+
@redirect = out
|
13
|
+
FileUtils.touch(@log)
|
11
14
|
|
12
|
-
@
|
15
|
+
@background = nil
|
16
|
+
end
|
17
|
+
|
18
|
+
def background
|
19
|
+
@background ||= ProcessSpawn.new(
|
13
20
|
@command,
|
14
|
-
timeout: timeout,
|
15
|
-
log: log,
|
16
|
-
out:
|
17
|
-
)
|
18
|
-
|
19
|
-
|
21
|
+
timeout: @timeout,
|
22
|
+
log: @log,
|
23
|
+
out: @redirect
|
24
|
+
).tap do |spawn|
|
25
|
+
puts "Spawning commmand: `#{spawn.command}`"
|
26
|
+
ProcessSpawn.add(@name, spawn)
|
27
|
+
end
|
20
28
|
end
|
21
29
|
|
22
30
|
def to_md(env = {})
|
@@ -24,14 +32,14 @@ class Rundoc::CodeCommand::Background
|
|
24
32
|
end
|
25
33
|
|
26
34
|
def call(env = {})
|
27
|
-
|
28
|
-
|
35
|
+
background.wait(@wait)
|
36
|
+
background.check_alive! unless @allow_fail
|
29
37
|
|
30
|
-
|
38
|
+
background.log.read
|
31
39
|
end
|
32
40
|
|
33
41
|
def alive?
|
34
|
-
|
42
|
+
!!background.alive?
|
35
43
|
end
|
36
44
|
end
|
37
45
|
end
|
@@ -6,10 +6,15 @@ class Rundoc::CodeCommand::Background
|
|
6
6
|
def initialize(contents, name:, wait:, timeout: 5, ending: $/)
|
7
7
|
@contents = contents
|
8
8
|
@ending = ending
|
9
|
-
@spawn = Rundoc::CodeCommand::Background::ProcessSpawn.find(name)
|
10
9
|
@wait = wait
|
10
|
+
@name = name
|
11
11
|
@timeout_value = Integer(timeout)
|
12
12
|
@contents_written = nil
|
13
|
+
@background = nil
|
14
|
+
end
|
15
|
+
|
16
|
+
def background
|
17
|
+
@background ||= Rundoc::CodeCommand::Background::ProcessSpawn.find(@name)
|
13
18
|
end
|
14
19
|
|
15
20
|
# The command is rendered (`:::>-`) by the output of the `def call` method.
|
@@ -20,11 +25,11 @@ class Rundoc::CodeCommand::Background
|
|
20
25
|
# The contents produced by the command (`:::->`) are rendered by the `def to_md` method.
|
21
26
|
def call(env = {})
|
22
27
|
writecontents
|
23
|
-
|
28
|
+
background.log.read
|
24
29
|
end
|
25
30
|
|
26
31
|
def writecontents
|
27
|
-
@contents_written ||=
|
32
|
+
@contents_written ||= background.stdin_write(
|
28
33
|
contents,
|
29
34
|
wait: @wait,
|
30
35
|
ending: @ending,
|
@@ -1,7 +1,12 @@
|
|
1
1
|
class Rundoc::CodeCommand::Background
|
2
2
|
class Stop < Rundoc::CodeCommand
|
3
3
|
def initialize(name:)
|
4
|
-
@
|
4
|
+
@name = name
|
5
|
+
@background = nil
|
6
|
+
end
|
7
|
+
|
8
|
+
def background
|
9
|
+
@background ||= Rundoc::CodeCommand::Background::ProcessSpawn.find(@name)
|
5
10
|
end
|
6
11
|
|
7
12
|
def to_md(env = {})
|
@@ -9,8 +14,8 @@ class Rundoc::CodeCommand::Background
|
|
9
14
|
end
|
10
15
|
|
11
16
|
def call(env = {})
|
12
|
-
|
13
|
-
|
17
|
+
background.stop
|
18
|
+
background.log.read
|
14
19
|
end
|
15
20
|
end
|
16
21
|
end
|
@@ -1,9 +1,14 @@
|
|
1
1
|
class Rundoc::CodeCommand::Background
|
2
2
|
class Wait < Rundoc::CodeCommand
|
3
3
|
def initialize(name:, wait:, timeout: 5)
|
4
|
-
@
|
4
|
+
@name = name
|
5
5
|
@wait = wait
|
6
6
|
@timeout_value = Integer(timeout)
|
7
|
+
@background = nil
|
8
|
+
end
|
9
|
+
|
10
|
+
def background
|
11
|
+
@background ||= Rundoc::CodeCommand::Background::ProcessSpawn.find(@name)
|
7
12
|
end
|
8
13
|
|
9
14
|
def to_md(env = {})
|
@@ -11,7 +16,7 @@ class Rundoc::CodeCommand::Background
|
|
11
16
|
end
|
12
17
|
|
13
18
|
def call(env = {})
|
14
|
-
|
19
|
+
background.wait(@wait, @timeout_value)
|
15
20
|
""
|
16
21
|
end
|
17
22
|
end
|
@@ -2,7 +2,11 @@ class Rundoc::CodeCommand::Website
|
|
2
2
|
class Navigate < Rundoc::CodeCommand
|
3
3
|
def initialize(name:)
|
4
4
|
@name = name
|
5
|
-
@driver =
|
5
|
+
@driver = nil
|
6
|
+
end
|
7
|
+
|
8
|
+
def driver
|
9
|
+
@driver ||= Rundoc::CodeCommand::Website::Driver.find(@name)
|
6
10
|
end
|
7
11
|
|
8
12
|
def to_md(env = {})
|
@@ -11,7 +15,7 @@ class Rundoc::CodeCommand::Website
|
|
11
15
|
|
12
16
|
def call(env = {})
|
13
17
|
puts "website.navigate [#{@name}]: #{contents}"
|
14
|
-
|
18
|
+
driver.safe_eval(contents, env)
|
15
19
|
""
|
16
20
|
end
|
17
21
|
|
@@ -1,8 +1,13 @@
|
|
1
1
|
class Rundoc::CodeCommand::Website
|
2
2
|
class Screenshot < Rundoc::CodeCommand
|
3
3
|
def initialize(name:, upload: false)
|
4
|
-
@
|
4
|
+
@name = name
|
5
5
|
@upload = upload
|
6
|
+
@driver = nil
|
7
|
+
end
|
8
|
+
|
9
|
+
def driver
|
10
|
+
@driver ||= Rundoc::CodeCommand::Website::Driver.find(@name)
|
6
11
|
end
|
7
12
|
|
8
13
|
def to_md(env = {})
|
@@ -10,14 +15,14 @@ class Rundoc::CodeCommand::Website
|
|
10
15
|
end
|
11
16
|
|
12
17
|
def call(env = {})
|
13
|
-
puts "Taking screenshot: #{
|
14
|
-
filename =
|
18
|
+
puts "Taking screenshot: #{driver.current_url}"
|
19
|
+
filename = driver.screenshot(
|
15
20
|
upload: @upload,
|
16
21
|
screenshots_dir: env[:context].screenshots_dir
|
17
22
|
)
|
18
23
|
|
19
24
|
relative_filename = filename.relative_path_from(env[:context].output_dir)
|
20
|
-
env[:before] << "![Screenshot of #{
|
25
|
+
env[:before] << "![Screenshot of #{driver.current_url}](#{relative_filename})"
|
21
26
|
""
|
22
27
|
end
|
23
28
|
|
@@ -6,14 +6,21 @@ class Rundoc::CodeCommand::Website
|
|
6
6
|
@name = name
|
7
7
|
@url = url
|
8
8
|
@scroll = scroll
|
9
|
-
@
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
9
|
+
@height = height
|
10
|
+
@width = width
|
11
|
+
@visible = visible
|
12
|
+
end
|
13
|
+
|
14
|
+
def driver
|
15
|
+
@driver ||= Driver.new(
|
16
|
+
name: @name,
|
17
|
+
url: @url,
|
18
|
+
height: @height,
|
19
|
+
width: @width,
|
20
|
+
visible: @visible
|
21
|
+
).tap do |driver|
|
22
|
+
Driver.add(@name, driver)
|
23
|
+
end
|
17
24
|
end
|
18
25
|
|
19
26
|
def to_md(env = {})
|
@@ -26,11 +33,11 @@ class Rundoc::CodeCommand::Website
|
|
26
33
|
|
27
34
|
puts message
|
28
35
|
|
29
|
-
|
30
|
-
|
36
|
+
driver.visit(@url) if @url
|
37
|
+
driver.scroll(@scroll) if @scroll
|
31
38
|
|
32
39
|
return "" if contents.nil? || contents.empty?
|
33
|
-
|
40
|
+
driver.safe_eval(contents, env)
|
34
41
|
|
35
42
|
""
|
36
43
|
end
|
data/lib/rundoc/version.rb
CHANGED
@@ -6,6 +6,8 @@ class IntegrationWebsiteTest < Minitest::Test
|
|
6
6
|
```
|
7
7
|
:::>> website.visit(name: "example", url: "http://example.com")
|
8
8
|
:::>> website.screenshot(name: "example")
|
9
|
+
:::>> website.navigate(name: "example")
|
10
|
+
session.execute_script "window.scrollBy(0,10)"
|
9
11
|
```
|
10
12
|
RUBY
|
11
13
|
|
@@ -4,16 +4,25 @@ class BackgroundTest < Minitest::Test
|
|
4
4
|
def test_stdin_with_cat_echo
|
5
5
|
Dir.mktmpdir do |dir|
|
6
6
|
Dir.chdir(dir) do
|
7
|
+
# Intentionally out of order, should not raise an error as long as "cat"
|
8
|
+
# command exists at execution time
|
9
|
+
stdin_write = Rundoc::CodeCommand::Background::StdinWrite.new(
|
10
|
+
"hello there",
|
11
|
+
name: "cat",
|
12
|
+
wait: "hello"
|
13
|
+
)
|
14
|
+
|
7
15
|
background_start = Rundoc::CodeCommand::Background::Start.new("cat",
|
8
16
|
name: "cat")
|
17
|
+
|
9
18
|
background_start.call
|
19
|
+
output = stdin_write.call
|
20
|
+
assert_equal("hello there" + $/, output)
|
10
21
|
|
11
|
-
|
12
|
-
"hello there",
|
22
|
+
Rundoc::CodeCommand::Background::Wait.new(
|
13
23
|
name: "cat",
|
14
24
|
wait: "hello"
|
15
25
|
).call
|
16
|
-
assert_equal("hello there" + $/, output)
|
17
26
|
|
18
27
|
Rundoc::CodeCommand::Background::Log::Clear.new(
|
19
28
|
name: "cat"
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rundoc
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 4.1.
|
4
|
+
version: 4.1.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Richard Schneeman
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2024-12-
|
11
|
+
date: 2024-12-16 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: thor
|