conjur-cli 4.14.0 → 4.15.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +5 -13
- data/CHANGELOG.md +5 -0
- data/bin/_conjur_completions.yaml +2 -0
- data/conjur.gemspec +4 -2
- data/features/step_definitions/dsl_steps.rb +1 -1
- data/lib/conjur/command.rb +17 -0
- data/lib/conjur/command/groups.rb +18 -0
- data/lib/conjur/command/hosts.rb +27 -1
- data/lib/conjur/command/init.rb +1 -1
- data/lib/conjur/command/rspec/describe_command.rb +1 -1
- data/lib/conjur/command/rspec/mock_services.rb +7 -7
- data/lib/conjur/command/rspec/output_matchers.rb +16 -38
- data/lib/conjur/command/users.rb +18 -0
- data/lib/conjur/command/variables.rb +17 -0
- data/lib/conjur/version.rb +1 -1
- data/spec/authn_spec.rb +9 -9
- data/spec/command/assets_spec.rb +20 -20
- data/spec/command/audit_spec.rb +9 -9
- data/spec/command/authn_spec.rb +8 -8
- data/spec/command/env_spec.rb +26 -26
- data/spec/command/groups_spec.rb +4 -4
- data/spec/command/hosts_spec.rb +2 -2
- data/spec/command/init_spec.rb +19 -10
- data/spec/command/layers_spec.rb +6 -6
- data/spec/command/policy_spec.rb +16 -16
- data/spec/command/pubkeys_spec.rb +9 -9
- data/spec/command/resources_spec.rb +26 -26
- data/spec/command/roles_spec.rb +14 -14
- data/spec/command/users_spec.rb +10 -10
- data/spec/command/variables_spec.rb +3 -3
- data/spec/command_spec.rb +7 -7
- data/spec/config_spec.rb +21 -21
- data/spec/dsl/runner_spec.rb +8 -8
- data/spec/env_spec.rb +45 -45
- metadata +59 -36
data/spec/dsl/runner_spec.rb
CHANGED
|
@@ -13,25 +13,25 @@ describe Conjur::DSL::Runner, logged_in: true do
|
|
|
13
13
|
end
|
|
14
14
|
}
|
|
15
15
|
before {
|
|
16
|
-
Conjur.
|
|
17
|
-
runner.
|
|
16
|
+
allow(Conjur).to receive(:account).and_return "the-account"
|
|
17
|
+
allow(runner).to receive(:api).and_return api
|
|
18
18
|
}
|
|
19
19
|
it "should populate the root ownerid" do
|
|
20
|
-
api.
|
|
21
|
-
api.
|
|
20
|
+
expect(api).to receive(:user).with("alice").and_return double("alice-exists", exists?: false)
|
|
21
|
+
expect(api).to receive(:create_user).with(id: "alice", ownerid: "user:bob").and_return alice
|
|
22
22
|
|
|
23
23
|
runner.owner = "user:bob"
|
|
24
24
|
runner.execute
|
|
25
25
|
end
|
|
26
26
|
it "should store the api_key in the context keyed by roleid" do
|
|
27
|
-
api.
|
|
28
|
-
api.
|
|
27
|
+
expect(api).to receive(:user).with("alice").and_return double("alice-exists", exists?: false)
|
|
28
|
+
expect(api).to receive(:create_user).with(id: "alice").and_return alice
|
|
29
29
|
|
|
30
30
|
runner.execute
|
|
31
31
|
|
|
32
|
-
runner.context['api_keys'].
|
|
32
|
+
expect(runner.context['api_keys']).to eq({
|
|
33
33
|
"the-account:user:alice" => "the-api-key"
|
|
34
|
-
}
|
|
34
|
+
})
|
|
35
35
|
end
|
|
36
36
|
|
|
37
37
|
it "doesn't store default env and stack in context" do
|
data/spec/env_spec.rb
CHANGED
|
@@ -7,7 +7,7 @@ describe Conjur::Env do
|
|
|
7
7
|
|
|
8
8
|
describe "requires either :file or :yaml parameter" do
|
|
9
9
|
before {
|
|
10
|
-
Conjur::Env.
|
|
10
|
+
expect_any_instance_of(Conjur::Env).not_to receive(:parse)
|
|
11
11
|
}
|
|
12
12
|
it "fails if both options are provided" do
|
|
13
13
|
expect { Conjur::Env.new(file: 'f', yaml: 'y') }.to raise_error ":file and :yaml options can not be provided together"
|
|
@@ -33,20 +33,20 @@ describe Conjur::Env do
|
|
|
33
33
|
|
|
34
34
|
describe "if :file parameter provided" do
|
|
35
35
|
it "does not catch any errors from File.read" do
|
|
36
|
-
Conjur::Env.
|
|
37
|
-
File.
|
|
36
|
+
expect_any_instance_of(Conjur::Env).not_to receive(:parse)
|
|
37
|
+
allow(File).to receive(:read).with('unexisting') { raise "Custom error" }
|
|
38
38
|
expect { Conjur::Env.new(file: 'unexisting') }.to raise_error "Custom error"
|
|
39
39
|
end
|
|
40
40
|
|
|
41
41
|
it "if file is readable, passes contents to #parse and stores result in @definition attribute" do
|
|
42
|
-
File.
|
|
43
|
-
Conjur::Env.
|
|
44
|
-
Conjur::Env.new(file:"somefile").instance_variable_get("@definition").
|
|
42
|
+
expect(File).to receive(:read).with("somefile").and_return(:file_contents)
|
|
43
|
+
expect_any_instance_of(Conjur::Env).to receive(:parse).with(:file_contents).and_return(:stub_parsed)
|
|
44
|
+
expect(Conjur::Env.new(file:"somefile").instance_variable_get("@definition")).to eq(:stub_parsed)
|
|
45
45
|
end
|
|
46
46
|
end
|
|
47
47
|
it "if :yaml parameter provided, passes it to #parse and stores result in @definition attribute" do
|
|
48
|
-
Conjur::Env.
|
|
49
|
-
Conjur::Env.new(yaml:"custom yaml").instance_variable_get("@definition").
|
|
48
|
+
expect_any_instance_of(Conjur::Env).to receive(:parse).with("custom yaml").and_return(:stub_parsed)
|
|
49
|
+
expect(Conjur::Env.new(yaml:"custom yaml").instance_variable_get("@definition")).to eq(:stub_parsed)
|
|
50
50
|
end
|
|
51
51
|
end
|
|
52
52
|
end
|
|
@@ -54,7 +54,7 @@ describe Conjur::Env do
|
|
|
54
54
|
describe "#parse (called from 'initialize')" do
|
|
55
55
|
|
|
56
56
|
it 'parses input as YAML and does not hide YAML errors' do
|
|
57
|
-
YAML.
|
|
57
|
+
expect(YAML).to receive(:load).with("custom yaml") { raise "Custom error" }
|
|
58
58
|
expect { Conjur::Env.new(yaml: "custom yaml") }.to raise_error "Custom error"
|
|
59
59
|
end
|
|
60
60
|
|
|
@@ -75,15 +75,15 @@ describe Conjur::Env do
|
|
|
75
75
|
|
|
76
76
|
it "Returns hash consisting of literals, ConjurTempfile and ConjurVariable objects" do
|
|
77
77
|
result = Conjur::Env.new(yaml: "{a: literal, b: !tmp 'sometmp', c: !var 'somevar'}").instance_variable_get("@definition")
|
|
78
|
-
result.keys.sort.
|
|
79
|
-
result["a"].
|
|
80
|
-
result["b"].
|
|
81
|
-
result["c"].
|
|
78
|
+
expect(result.keys.sort).to eq(["a","b","c"])
|
|
79
|
+
expect(result["a"]).to eq('literal')
|
|
80
|
+
expect(result["b"]).to be_a_kind_of(Conjur::Env::ConjurTempfile)
|
|
81
|
+
expect(result["c"]).to be_a_kind_of(Conjur::Env::ConjurVariable)
|
|
82
82
|
end
|
|
83
83
|
|
|
84
84
|
it "Converts numbers to string literals" do
|
|
85
85
|
result = Conjur::Env.new(yaml: "{a: 123}").instance_variable_get("@definition")
|
|
86
|
-
result["a"].
|
|
86
|
+
expect(result["a"]).to eq("123")
|
|
87
87
|
end
|
|
88
88
|
|
|
89
89
|
end
|
|
@@ -91,34 +91,34 @@ describe Conjur::Env do
|
|
|
91
91
|
describe "#obtain", logged_in: true do
|
|
92
92
|
let(:subject) { Conjur::Env.new(yaml: "{a: literal, b: !tmp tempfile, c: !var conjurvar}") }
|
|
93
93
|
before {
|
|
94
|
-
api.
|
|
94
|
+
allow(api).to receive(:variable_values).with(["tempfile","conjurvar"]).and_return({"tempfile" => "stubtemp", "conjurvar" => "stubvar" })
|
|
95
95
|
}
|
|
96
96
|
|
|
97
97
|
it "requests variable_values with list of !var and !tmp values" do
|
|
98
|
-
Conjur::Env::ConjurTempfile.
|
|
99
|
-
api.
|
|
98
|
+
allow_any_instance_of(Conjur::Env::ConjurTempfile).to receive(:evaluate).and_return(:stub_value) # avoid tempfiles creation
|
|
99
|
+
expect(api).to receive(:variable_values).with(["tempfile","conjurvar"]).and_return({"tempfile" => "stub1", "conjurvar" => "stub2" })
|
|
100
100
|
subject.obtain(api)
|
|
101
101
|
end
|
|
102
102
|
|
|
103
103
|
it 'does not suppress api errors' do
|
|
104
|
-
api.
|
|
104
|
+
allow(api).to receive(:variable_values) { raise "Custom API error" }
|
|
105
105
|
expect { subject.obtain(api) }.to raise_error "Custom API error"
|
|
106
106
|
end
|
|
107
107
|
|
|
108
108
|
describe "for !tmp creates temporary files with Conjur variable value" do
|
|
109
109
|
it "in /dev/shm if it exists" do
|
|
110
110
|
tempfile = double(path: '/dev/shm/newfile', close: true)
|
|
111
|
-
File.
|
|
112
|
-
File.
|
|
113
|
-
Tempfile.
|
|
114
|
-
tempfile.
|
|
111
|
+
expect(File).to receive(:directory?).with("/dev/shm").and_return(true)
|
|
112
|
+
expect(File).to receive(:writable?).with("/dev/shm").and_return(true)
|
|
113
|
+
expect(Tempfile).to receive(:new).with("conjur","/dev/shm").and_return(tempfile)
|
|
114
|
+
expect(tempfile).to receive(:write).with("stubtemp")
|
|
115
115
|
subject.obtain(api)
|
|
116
116
|
end
|
|
117
117
|
it "otherwise uses Tempfile defaults" do
|
|
118
118
|
tempfile = double(path: '/tmp/newfile', close: true)
|
|
119
|
-
File.
|
|
120
|
-
Tempfile.
|
|
121
|
-
tempfile.
|
|
119
|
+
expect(File).to receive(:directory?).with("/dev/shm").and_return(false)
|
|
120
|
+
expect(Tempfile).to receive(:new).with("conjur").and_return(tempfile)
|
|
121
|
+
expect(tempfile).to receive(:write).with("stubtemp")
|
|
122
122
|
subject.obtain(api)
|
|
123
123
|
end
|
|
124
124
|
end
|
|
@@ -126,20 +126,20 @@ describe Conjur::Env do
|
|
|
126
126
|
describe "returns hash consisting of original keys and following values" do
|
|
127
127
|
before {
|
|
128
128
|
tempfile=double(path:"/stub/tempfile",write: true, close: true)
|
|
129
|
-
File.
|
|
130
|
-
File.
|
|
131
|
-
Tempfile.
|
|
129
|
+
allow(File).to receive(:directory?).with("/dev/shm").and_return(true)
|
|
130
|
+
allow(File).to receive(:writable?).with("/dev/shm").and_return(true)
|
|
131
|
+
allow(Tempfile).to receive(:new).with("conjur","/dev/shm").and_return(tempfile)
|
|
132
132
|
}
|
|
133
133
|
let(:result) { subject.obtain(api) }
|
|
134
134
|
|
|
135
135
|
it 'literals' do
|
|
136
|
-
result.
|
|
136
|
+
expect(result).to include("a"=>"literal")
|
|
137
137
|
end
|
|
138
138
|
it '!tmp: names of temp files' do
|
|
139
|
-
result.
|
|
139
|
+
expect(result).to include("b"=>"/stub/tempfile")
|
|
140
140
|
end
|
|
141
141
|
it '!var: variable values' do
|
|
142
|
-
result.
|
|
142
|
+
expect(result).to include("c"=>"stubvar")
|
|
143
143
|
end
|
|
144
144
|
end
|
|
145
145
|
end
|
|
@@ -148,38 +148,38 @@ describe Conjur::Env do
|
|
|
148
148
|
|
|
149
149
|
let(:subject) { Conjur::Env.new(yaml: "{a: literal, b: !tmp tempfile_b, c: !var conjurvar_c, d: !tmp tempfile_d, e: !var conjurvar_e }") }
|
|
150
150
|
before {
|
|
151
|
-
api.
|
|
152
|
-
Tempfile.
|
|
151
|
+
expect(api).not_to receive(:variable_values)
|
|
152
|
+
expect(Tempfile).not_to receive(:new)
|
|
153
153
|
}
|
|
154
154
|
let(:permitted) { double(permitted?:true) }
|
|
155
155
|
let(:restricted) { double(permitted?:false) }
|
|
156
156
|
|
|
157
157
|
it "requests resource 'execute' permission for each !var and !tmp value" do
|
|
158
|
-
api.
|
|
159
|
-
api.
|
|
160
|
-
api.
|
|
161
|
-
api.
|
|
162
|
-
permitted.
|
|
158
|
+
expect(api).to receive(:resource).with("variable:tempfile_b").and_return(permitted)
|
|
159
|
+
expect(api).to receive(:resource).with("variable:conjurvar_c").and_return(permitted)
|
|
160
|
+
expect(api).to receive(:resource).with("variable:tempfile_d").and_return(permitted)
|
|
161
|
+
expect(api).to receive(:resource).with("variable:conjurvar_e").and_return(permitted)
|
|
162
|
+
expect(permitted).to receive(:permitted?).exactly(4).times.with(:execute).and_return(true)
|
|
163
163
|
subject.check(api)
|
|
164
164
|
end
|
|
165
165
|
|
|
166
166
|
it 'does not rescue from unexpected api errors' do
|
|
167
|
-
api.
|
|
167
|
+
expect(api).to receive(:resource).with("variable:tempfile_b") { raise "Custom error" }
|
|
168
168
|
expect { subject.check(api) }.to raise_error "Custom error"
|
|
169
169
|
end
|
|
170
170
|
|
|
171
171
|
it "returns Hash consisting of original keys and following statuses: :literal, :available, :unavailable" do
|
|
172
|
-
api.
|
|
173
|
-
api.
|
|
174
|
-
api.
|
|
175
|
-
api.
|
|
172
|
+
expect(api).to receive(:resource).with("variable:tempfile_b").and_return(permitted)
|
|
173
|
+
expect(api).to receive(:resource).with("variable:conjurvar_c").and_return(restricted)
|
|
174
|
+
expect(api).to receive(:resource).with("variable:tempfile_d").and_return(restricted)
|
|
175
|
+
expect(api).to receive(:resource).with("variable:conjurvar_e").and_return(permitted)
|
|
176
176
|
|
|
177
|
-
result = subject.check(api).
|
|
177
|
+
result = expect(subject.check(api)).to eq({ "a" => :literal,
|
|
178
178
|
"b" => :available,
|
|
179
179
|
"c" => :unavailable,
|
|
180
180
|
"d" => :unavailable,
|
|
181
181
|
"e" => :available
|
|
182
|
-
}
|
|
182
|
+
})
|
|
183
183
|
end
|
|
184
184
|
end
|
|
185
185
|
|
metadata
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
|
2
2
|
name: conjur-cli
|
|
3
3
|
version: !ruby/object:Gem::Version
|
|
4
|
-
version: 4.
|
|
4
|
+
version: 4.15.0
|
|
5
5
|
platform: ruby
|
|
6
6
|
authors:
|
|
7
7
|
- Rafał Rzepecki
|
|
@@ -9,182 +9,190 @@ authors:
|
|
|
9
9
|
autorequire:
|
|
10
10
|
bindir: bin
|
|
11
11
|
cert_chain: []
|
|
12
|
-
date: 2014-09-
|
|
12
|
+
date: 2014-09-22 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
|
14
14
|
- !ruby/object:Gem::Dependency
|
|
15
15
|
name: activesupport
|
|
16
16
|
requirement: !ruby/object:Gem::Requirement
|
|
17
17
|
requirements:
|
|
18
|
-
- -
|
|
18
|
+
- - '>='
|
|
19
19
|
- !ruby/object:Gem::Version
|
|
20
20
|
version: '0'
|
|
21
21
|
type: :runtime
|
|
22
22
|
prerelease: false
|
|
23
23
|
version_requirements: !ruby/object:Gem::Requirement
|
|
24
24
|
requirements:
|
|
25
|
-
- -
|
|
25
|
+
- - '>='
|
|
26
26
|
- !ruby/object:Gem::Version
|
|
27
27
|
version: '0'
|
|
28
28
|
- !ruby/object:Gem::Dependency
|
|
29
29
|
name: conjur-api
|
|
30
30
|
requirement: !ruby/object:Gem::Requirement
|
|
31
31
|
requirements:
|
|
32
|
-
- -
|
|
32
|
+
- - '>='
|
|
33
33
|
- !ruby/object:Gem::Version
|
|
34
34
|
version: 4.10.0
|
|
35
35
|
type: :runtime
|
|
36
36
|
prerelease: false
|
|
37
37
|
version_requirements: !ruby/object:Gem::Requirement
|
|
38
38
|
requirements:
|
|
39
|
-
- -
|
|
39
|
+
- - '>='
|
|
40
40
|
- !ruby/object:Gem::Version
|
|
41
41
|
version: 4.10.0
|
|
42
42
|
- !ruby/object:Gem::Dependency
|
|
43
43
|
name: gli
|
|
44
44
|
requirement: !ruby/object:Gem::Requirement
|
|
45
45
|
requirements:
|
|
46
|
-
- -
|
|
46
|
+
- - '>='
|
|
47
47
|
- !ruby/object:Gem::Version
|
|
48
48
|
version: 2.8.0
|
|
49
49
|
type: :runtime
|
|
50
50
|
prerelease: false
|
|
51
51
|
version_requirements: !ruby/object:Gem::Requirement
|
|
52
52
|
requirements:
|
|
53
|
-
- -
|
|
53
|
+
- - '>='
|
|
54
54
|
- !ruby/object:Gem::Version
|
|
55
55
|
version: 2.8.0
|
|
56
56
|
- !ruby/object:Gem::Dependency
|
|
57
57
|
name: highline
|
|
58
58
|
requirement: !ruby/object:Gem::Requirement
|
|
59
59
|
requirements:
|
|
60
|
-
- -
|
|
60
|
+
- - '>='
|
|
61
61
|
- !ruby/object:Gem::Version
|
|
62
62
|
version: '0'
|
|
63
63
|
type: :runtime
|
|
64
64
|
prerelease: false
|
|
65
65
|
version_requirements: !ruby/object:Gem::Requirement
|
|
66
66
|
requirements:
|
|
67
|
-
- -
|
|
67
|
+
- - '>='
|
|
68
68
|
- !ruby/object:Gem::Version
|
|
69
69
|
version: '0'
|
|
70
70
|
- !ruby/object:Gem::Dependency
|
|
71
71
|
name: netrc
|
|
72
72
|
requirement: !ruby/object:Gem::Requirement
|
|
73
73
|
requirements:
|
|
74
|
-
- -
|
|
74
|
+
- - '>='
|
|
75
75
|
- !ruby/object:Gem::Version
|
|
76
76
|
version: '0'
|
|
77
77
|
type: :runtime
|
|
78
78
|
prerelease: false
|
|
79
79
|
version_requirements: !ruby/object:Gem::Requirement
|
|
80
80
|
requirements:
|
|
81
|
-
- -
|
|
81
|
+
- - '>='
|
|
82
82
|
- !ruby/object:Gem::Version
|
|
83
83
|
version: '0'
|
|
84
84
|
- !ruby/object:Gem::Dependency
|
|
85
85
|
name: methadone
|
|
86
86
|
requirement: !ruby/object:Gem::Requirement
|
|
87
87
|
requirements:
|
|
88
|
-
- -
|
|
88
|
+
- - '>='
|
|
89
89
|
- !ruby/object:Gem::Version
|
|
90
90
|
version: '0'
|
|
91
91
|
type: :runtime
|
|
92
92
|
prerelease: false
|
|
93
93
|
version_requirements: !ruby/object:Gem::Requirement
|
|
94
94
|
requirements:
|
|
95
|
-
- -
|
|
95
|
+
- - '>='
|
|
96
96
|
- !ruby/object:Gem::Version
|
|
97
97
|
version: '0'
|
|
98
98
|
- !ruby/object:Gem::Dependency
|
|
99
99
|
name: deep_merge
|
|
100
100
|
requirement: !ruby/object:Gem::Requirement
|
|
101
101
|
requirements:
|
|
102
|
-
- -
|
|
102
|
+
- - '>='
|
|
103
103
|
- !ruby/object:Gem::Version
|
|
104
104
|
version: '0'
|
|
105
105
|
type: :runtime
|
|
106
106
|
prerelease: false
|
|
107
107
|
version_requirements: !ruby/object:Gem::Requirement
|
|
108
108
|
requirements:
|
|
109
|
-
- -
|
|
109
|
+
- - '>='
|
|
110
110
|
- !ruby/object:Gem::Version
|
|
111
111
|
version: '0'
|
|
112
112
|
- !ruby/object:Gem::Dependency
|
|
113
113
|
name: cas_rest_client
|
|
114
114
|
requirement: !ruby/object:Gem::Requirement
|
|
115
115
|
requirements:
|
|
116
|
-
- -
|
|
116
|
+
- - '>='
|
|
117
117
|
- !ruby/object:Gem::Version
|
|
118
118
|
version: '0'
|
|
119
119
|
type: :runtime
|
|
120
120
|
prerelease: false
|
|
121
121
|
version_requirements: !ruby/object:Gem::Requirement
|
|
122
122
|
requirements:
|
|
123
|
-
- -
|
|
123
|
+
- - '>='
|
|
124
124
|
- !ruby/object:Gem::Version
|
|
125
125
|
version: '0'
|
|
126
126
|
- !ruby/object:Gem::Dependency
|
|
127
127
|
name: rspec
|
|
128
128
|
requirement: !ruby/object:Gem::Requirement
|
|
129
129
|
requirements:
|
|
130
|
-
- -
|
|
131
|
-
- !ruby/object:Gem::Version
|
|
132
|
-
version: '2.14'
|
|
133
|
-
- - <
|
|
130
|
+
- - ~>
|
|
134
131
|
- !ruby/object:Gem::Version
|
|
135
132
|
version: '3.0'
|
|
136
133
|
type: :development
|
|
137
134
|
prerelease: false
|
|
138
135
|
version_requirements: !ruby/object:Gem::Requirement
|
|
139
136
|
requirements:
|
|
140
|
-
- -
|
|
141
|
-
- !ruby/object:Gem::Version
|
|
142
|
-
version: '2.14'
|
|
143
|
-
- - <
|
|
137
|
+
- - ~>
|
|
144
138
|
- !ruby/object:Gem::Version
|
|
145
139
|
version: '3.0'
|
|
146
140
|
- !ruby/object:Gem::Dependency
|
|
147
141
|
name: simplecov
|
|
148
142
|
requirement: !ruby/object:Gem::Requirement
|
|
149
143
|
requirements:
|
|
150
|
-
- -
|
|
144
|
+
- - '>='
|
|
151
145
|
- !ruby/object:Gem::Version
|
|
152
146
|
version: '0'
|
|
153
147
|
type: :development
|
|
154
148
|
prerelease: false
|
|
155
149
|
version_requirements: !ruby/object:Gem::Requirement
|
|
156
150
|
requirements:
|
|
157
|
-
- -
|
|
151
|
+
- - '>='
|
|
158
152
|
- !ruby/object:Gem::Version
|
|
159
153
|
version: '0'
|
|
160
154
|
- !ruby/object:Gem::Dependency
|
|
161
155
|
name: aruba
|
|
162
156
|
requirement: !ruby/object:Gem::Requirement
|
|
163
157
|
requirements:
|
|
164
|
-
- -
|
|
158
|
+
- - '>='
|
|
165
159
|
- !ruby/object:Gem::Version
|
|
166
160
|
version: '0'
|
|
167
161
|
type: :development
|
|
168
162
|
prerelease: false
|
|
169
163
|
version_requirements: !ruby/object:Gem::Requirement
|
|
170
164
|
requirements:
|
|
171
|
-
- -
|
|
165
|
+
- - '>='
|
|
172
166
|
- !ruby/object:Gem::Version
|
|
173
167
|
version: '0'
|
|
174
168
|
- !ruby/object:Gem::Dependency
|
|
175
|
-
name:
|
|
169
|
+
name: ci_reporter_rspec
|
|
176
170
|
requirement: !ruby/object:Gem::Requirement
|
|
177
171
|
requirements:
|
|
178
172
|
- - ~>
|
|
179
173
|
- !ruby/object:Gem::Version
|
|
180
|
-
version: '1.
|
|
174
|
+
version: '1.0'
|
|
181
175
|
type: :development
|
|
182
176
|
prerelease: false
|
|
183
177
|
version_requirements: !ruby/object:Gem::Requirement
|
|
184
178
|
requirements:
|
|
185
179
|
- - ~>
|
|
186
180
|
- !ruby/object:Gem::Version
|
|
187
|
-
version: '1.
|
|
181
|
+
version: '1.0'
|
|
182
|
+
- !ruby/object:Gem::Dependency
|
|
183
|
+
name: ci_reporter_cucumber
|
|
184
|
+
requirement: !ruby/object:Gem::Requirement
|
|
185
|
+
requirements:
|
|
186
|
+
- - '>='
|
|
187
|
+
- !ruby/object:Gem::Version
|
|
188
|
+
version: '0'
|
|
189
|
+
type: :development
|
|
190
|
+
prerelease: false
|
|
191
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
192
|
+
requirements:
|
|
193
|
+
- - '>='
|
|
194
|
+
- !ruby/object:Gem::Version
|
|
195
|
+
version: '0'
|
|
188
196
|
- !ruby/object:Gem::Dependency
|
|
189
197
|
name: rake
|
|
190
198
|
requirement: !ruby/object:Gem::Requirement
|
|
@@ -199,6 +207,20 @@ dependencies:
|
|
|
199
207
|
- - ~>
|
|
200
208
|
- !ruby/object:Gem::Version
|
|
201
209
|
version: '10.0'
|
|
210
|
+
- !ruby/object:Gem::Dependency
|
|
211
|
+
name: io-grab
|
|
212
|
+
requirement: !ruby/object:Gem::Requirement
|
|
213
|
+
requirements:
|
|
214
|
+
- - ~>
|
|
215
|
+
- !ruby/object:Gem::Version
|
|
216
|
+
version: 0.0.1
|
|
217
|
+
type: :development
|
|
218
|
+
prerelease: false
|
|
219
|
+
version_requirements: !ruby/object:Gem::Requirement
|
|
220
|
+
requirements:
|
|
221
|
+
- - ~>
|
|
222
|
+
- !ruby/object:Gem::Version
|
|
223
|
+
version: 0.0.1
|
|
202
224
|
description:
|
|
203
225
|
email:
|
|
204
226
|
- divided.mind@gmail.com
|
|
@@ -215,6 +237,7 @@ files:
|
|
|
215
237
|
- .gitignore
|
|
216
238
|
- .kateproject
|
|
217
239
|
- .project
|
|
240
|
+
- CHANGELOG.md
|
|
218
241
|
- Gemfile
|
|
219
242
|
- LICENSE
|
|
220
243
|
- README.md
|
|
@@ -302,17 +325,17 @@ require_paths:
|
|
|
302
325
|
- lib
|
|
303
326
|
required_ruby_version: !ruby/object:Gem::Requirement
|
|
304
327
|
requirements:
|
|
305
|
-
- -
|
|
328
|
+
- - '>='
|
|
306
329
|
- !ruby/object:Gem::Version
|
|
307
330
|
version: '0'
|
|
308
331
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
|
309
332
|
requirements:
|
|
310
|
-
- -
|
|
333
|
+
- - '>='
|
|
311
334
|
- !ruby/object:Gem::Version
|
|
312
335
|
version: '0'
|
|
313
336
|
requirements: []
|
|
314
337
|
rubyforge_project:
|
|
315
|
-
rubygems_version: 2.2.
|
|
338
|
+
rubygems_version: 2.2.1
|
|
316
339
|
signing_key:
|
|
317
340
|
specification_version: 4
|
|
318
341
|
summary: Conjur command line interface
|