-
Notifications
You must be signed in to change notification settings - Fork 552
/
invocation_spec.rb
107 lines (87 loc) · 3.34 KB
/
invocation_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
require File.expand_path(File.dirname(__FILE__) + '/spec_helper')
require 'thor/base'
describe Thor::Invocation do
describe "#invoke" do
it "invokes a task inside another task" do
capture(:stdout){ A.new.invoke(:two) }.must == "2\n3\n"
end
it "invokes a task just once" do
capture(:stdout){ A.new.invoke(:one) }.must == "1\n2\n3\n"
end
it "invokes a task just once even if they belongs to different classes" do
capture(:stdout){ Defined.new.invoke(:one) }.must == "1\n2\n3\n4\n5\n"
end
it "invokes a task with arguments" do
A.new.invoke(:five, [5]).must be_true
A.new.invoke(:five, [7]).must be_false
end
it "invokes the default task if none is given to a Thor class" do
content = capture(:stdout){ A.new.invoke("b") }
content.must =~ /Tasks/
content.must =~ /LAST_NAME/
end
it "accepts a class as argument without a task to invoke" do
content = capture(:stdout){ A.new.invoke(B) }
content.must =~ /Tasks/
content.must =~ /LAST_NAME/
end
it "accepts a class as argument with a task to invoke" do
base = A.new([], :last_name => "Valim")
base.invoke(B, :one, ["Jose"]).must == "Valim, Jose"
end
it "accepts a Thor instance as argument" do
invoked = B.new([], :last_name => "Valim")
base = A.new
base.invoke(invoked, :one, ["Jose"]).must == "Valim, Jose"
base.invoke(invoked, :one, ["Jose"]).must be_nil
end
it "allows customized options to be given" do
base = A.new([], :last_name => "Wrong")
base.invoke(B, :one, ["Jose"], :last_name => "Valim").must == "Valim, Jose"
end
it "reparses options in the new class" do
A.start(["invoker", "--last-name", "Valim"]).must == "Valim, Jose"
end
it "shares initialize options with invoked class" do
A.new([], :foo => :bar).invoke("b:two").must == { "foo" => :bar }
end
it "dump configuration values to be used in the invoked class" do
base = A.new
base.invoke("b:three").shell.must == base.shell
end
it "allow extra configuration values to be given" do
base, shell = A.new, Thor::Base.shell.new
base.invoke("b:three", [], {}, :shell => shell).shell.must == shell
end
it "invokes a Thor::Group and all of its tasks" do
capture(:stdout){ A.new.invoke(:c) }.must == "1\n2\n3\n"
end
it "does not invoke a Thor::Group twice" do
base = A.new
silence(:stdout){ base.invoke(:c) }
capture(:stdout){ base.invoke(:c) }.must be_empty
end
it "does not invoke any of Thor::Group tasks twice" do
base = A.new
silence(:stdout){ base.invoke(:c) }
capture(:stdout){ base.invoke("c:one") }.must be_empty
end
it "raises Thor::UndefinedTaskError if the task can't be found" do
lambda do
A.new.invoke("foo:bar")
end.must raise_error(Thor::UndefinedTaskError)
end
it "raises Thor::UndefinedTaskError if the task can't be found even if all tasks where already executed" do
base = C.new
silence(:stdout){ base.invoke }
lambda do
base.invoke("foo:bar")
end.must raise_error(Thor::UndefinedTaskError)
end
it "raises an error if a non Thor class is given" do
lambda do
A.new.invoke(Object)
end.must raise_error(RuntimeError, "Expected Thor class, got Object")
end
end
end