rainforest-cli 0.0.13 → 0.0.14

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: 72def45d00f529b7b7c35d23b097dbe3e0e0ea89
4
- data.tar.gz: 0a6312c46e0862e24272881e6adb6fc22c477423
3
+ metadata.gz: 0f42f5204c7270c3eac865f11542df5a4018a95a
4
+ data.tar.gz: 4d3e1c7e16bbb265f6d1fb0f9f3602b8f48dc8e5
5
5
  SHA512:
6
- metadata.gz: 1a1c28ebb3bce9b4ef7788b75c098055f7b83f588d1797a547d44c65d7490cef80ccb43179873f8fbcbd9d5dac095bc567d40904c3dd596f0d2cb011d9623579
7
- data.tar.gz: 4a37fbeb379b70c1f7b8b284ff5f61c56fc02c7a26a35f8b893bdb53879ed48a2ce0fd3954670db3cab7a8f0b24aca467c48fbe34b56e991191b384ba9fbf8b4
6
+ metadata.gz: 39cac3328e88e9d2cc174c0386f135ff11d7cd52b012b0daea620733a3aab1e0f7f0ee02623c156e1a2eb8e69c55422426f2c3a2364aff7c84f447b9e583abc7
7
+ data.tar.gz: 9cd678e820f6dc9385a2db12b4d5d29ea58dbb50c590a48a055f4723bb734dc5ff9ab2b89046420b408f2aca2cb4196d3b93d19e5190067a6fd694fe55a76d6e
checksums.yaml.gz.sig CHANGED
Binary file
data/.travis.yml CHANGED
@@ -1,7 +1,7 @@
1
1
  language: ruby
2
2
  rvm:
3
+ - 2.1.2
3
4
  - 2.0.0
4
5
  - 1.9.3
5
- - ruby-head
6
6
 
7
7
  script: bundle exec rspec spec
data/README.md CHANGED
@@ -36,6 +36,8 @@ The options are:
36
36
  - `--conflict abort` - if you trigger rainforest more than once, anything running will be aborted and a fresh run started
37
37
  - `--fail-fast` - fail the build as soon as the first failed result comes in. If you don't pass this it will wait until 100% of the run is done
38
38
  - `--fg` - results in the foreground - this is what you want to make the build pass / fail dependent on rainforest results
39
+ - `--site-id` - only run tests for a specific site. Get in touch with us for help on getting that you site id if you are unable to.
40
+ - `--custom-url` - use a custom url for this run. Example use case: an ad-hoc QA environment with [Fourchette](https://github.com/rainforestapp/fourchette). You will need to specify a `site_id` too for this to work. Please note that we will be creating environments under the hood and will not affect your test permanently.
39
41
 
40
42
 
41
43
  ## Contributing
data/certs/ukd1.pem ADDED
@@ -0,0 +1,22 @@
1
+ -----BEGIN CERTIFICATE-----
2
+ MIIDljCCAn6gAwIBAgIBATANBgkqhkiG9w0BAQUFADBIMR0wGwYDVQQDDBRydXNz
3
+ ZWxsLmhvd2FyZC5zbWl0aDESMBAGCgmSJomT8ixkARkWAm1lMRMwEQYKCZImiZPy
4
+ LGQBGRYDY29tMB4XDTE0MDgxNDA1Mzc0NloXDTE1MDgxNDA1Mzc0NlowSDEdMBsG
5
+ A1UEAwwUcnVzc2VsbC5ob3dhcmQuc21pdGgxEjAQBgoJkiaJk/IsZAEZFgJtZTET
6
+ MBEGCgmSJomT8ixkARkWA2NvbTCCASIwDQYJKoZIhvcNAQEBBQADggEPADCCAQoC
7
+ ggEBAKSK3Sfhs+miX1jdDywi9Khl1QjIn2DUM1U+bou6WLkQaOUtqhX/T2jHltQ9
8
+ Olc7jaz4XO5g+YngELX2tGFA6zbUnvaHXnPz23hPsP5TUErFAI1VJYl9fmQY6sEd
9
+ komCT8jZwB09Re20iyZtNsEMa8gagR7qX1wgPVqxAncE7OJ5stwHxcSQABfGrInF
10
+ sdZyjqNE2D0NxWZoWTC7CERaRNUm12y4NpHm6fdvtbgsB14WQjaqOYYUmFffT89Y
11
+ c0TOOGUV1aMbjpRUZFhu/tAaWGW+GfZnln9F3GWYJMRzC5k8+awB1vXgnfqZH007
12
+ ef85jyOutXfKKYyXcWlvrDMoTTUCAwEAAaOBijCBhzAJBgNVHRMEAjAAMAsGA1Ud
13
+ DwQEAwIEsDAdBgNVHQ4EFgQUFws4YIAtrBiQdbpWgqwcYd/+Hh4wJgYDVR0RBB8w
14
+ HYEbcnVzc2VsbC5ob3dhcmQuc21pdGhAbWUuY29tMCYGA1UdEgQfMB2BG3J1c3Nl
15
+ bGwuaG93YXJkLnNtaXRoQG1lLmNvbTANBgkqhkiG9w0BAQUFAAOCAQEADHQJiURU
16
+ PJbfReV/MgIum917Vktz9Zv1GPzKzY5EkIL34FylaSernkITWe6GcsMb8yNrdG/1
17
+ eSyAvx32v/L3ef2mp7kHXbtzcXBq3xyCewfH6AfX3dm65CfgaeGx+qK/F/bl0iiZ
18
+ SQpNWk3RB/7deQThk3SYD8jS8n1d7KSRLogpXnSNWRyaSHtZ2x7T2qVpn4lp1PIi
19
+ /4Hg5bJrO0VqDlVG8UvsFbFB24ZNDQVq73MLZFNez0UBhOZVo4kBlSUvyEv5YLlA
20
+ wWdLLpBZZ1O4GE0uzQovmTiis4iyCF+8tFIgjbM/FVwKUBV6OZpxs4FOBtR1mK6L
21
+ lj0cPcKRm/FZUw==
22
+ -----END CERTIFICATE-----
@@ -10,7 +10,8 @@ module Rainforest
10
10
  end
11
11
 
12
12
  class OptionParser
13
- attr_reader :command, :token, :tags, :conflict, :browsers, :import_file_name, :import_name
13
+ attr_reader :command, :token, :tags, :conflict, :browsers, :site_id,
14
+ :import_file_name, :import_name, :custom_url
14
15
 
15
16
  VALID_BROWSERS = %w{chrome firefox safari ie8 ie9}.freeze
16
17
 
@@ -53,6 +54,14 @@ module Rainforest
53
54
  opts.on("--conflict MODE", String, "How should Rainforest handle existing in progress runs?") do |value|
54
55
  @conflict = value
55
56
  end
57
+
58
+ opts.on("--site-id ID", Integer, "Only run tests for a specific site") do |value|
59
+ @site_id = value
60
+ end
61
+
62
+ opts.on("--custom-url URL", String, "Use a custom url for this run. You will need to specify a site_id too for this to work.") do |value|
63
+ @custom_url = value
64
+ end
56
65
  end.parse!(@args)
57
66
 
58
67
  @command = @args.shift
@@ -1,5 +1,5 @@
1
1
  module Rainforest
2
2
  module Cli
3
- VERSION = "0.0.13"
3
+ VERSION = "0.0.14"
4
4
  end
5
5
  end
@@ -10,13 +10,18 @@ module Rainforest
10
10
 
11
11
  def self.start(args)
12
12
  @options = OptionParser.new(args)
13
-
13
+
14
+ if @options.custom_url && @options.site_id.nil?
15
+ puts "The site-id and custom-url options work together, you need both of them."
16
+ exit 1
17
+ end
18
+
14
19
  if @options.import_file_name && @options.import_name
15
20
  unless File.exists?(@options.import_file_name)
16
21
  puts "Input file: #{@options.import_file_name} not found"
17
22
  exit 2
18
23
  end
19
-
24
+
20
25
  delete_generator(@options.import_name)
21
26
  CSVImporter.new(@options.import_name, @options.import_file_name, @options.token).import
22
27
  elsif @options.import_file_name || @options.import_name
@@ -33,8 +38,11 @@ module Rainforest
33
38
 
34
39
  post_opts[:conflict] = @options.conflict if @options.conflict
35
40
  post_opts[:browsers] = @options.browsers if @options.browsers
41
+ post_opts[:site_id] = @options.site_id if @options.site_id
36
42
  post_opts[:gem_version] = Rainforest::Cli::VERSION
37
43
 
44
+ post_opts[:environment_id] = get_environment_id(@options.custom_url) if @options.custom_url
45
+
38
46
  puts "Issuing run"
39
47
 
40
48
  response = post(API_URL + '/runs', post_opts)
@@ -68,11 +76,11 @@ module Rainforest
68
76
  end
69
77
  true
70
78
  end
71
-
79
+
72
80
  def self.list_generators
73
81
  get("#{API_URL}/generators")
74
82
  end
75
-
83
+
76
84
  def self.delete_generator(name)
77
85
  generator = list_generators.find {|g| g['type'] == 'custom' && g['key'] == name }
78
86
  delete("#{API_URL}/generators/#{generator['id']}") if generator
@@ -83,7 +91,7 @@ module Rainforest
83
91
  body: body,
84
92
  headers: {"CLIENT_TOKEN" => @options.token}
85
93
  }
86
-
94
+
87
95
  JSON.parse(response.body)
88
96
  end
89
97
 
@@ -108,5 +116,26 @@ module Rainforest
108
116
  nil
109
117
  end
110
118
  end
119
+
120
+ def self.get_environment_id url
121
+ begin
122
+ URI.parse(url)
123
+ rescue URI::InvalidURIError
124
+ puts "The custom URL is invalid"
125
+ exit 1
126
+ end
127
+
128
+ env_post_body = { name: 'temporary-env-for-custom-url-via-CLI', url: url }
129
+ environment = post("#{API_URL}/environments", env_post_body)
130
+
131
+ if environment['error']
132
+ # I am talking about a URL here because the environments are pretty
133
+ # much hidden from clients so far.
134
+ puts "Error creating the ad-hoc URL: #{environment['error']}"
135
+ exit 1
136
+ end
137
+
138
+ return environment['id']
139
+ end
111
140
  end
112
141
  end
data/spec/cli_spec.rb CHANGED
@@ -1,12 +1,70 @@
1
1
  describe Rainforest::Cli do
2
2
  before do
3
3
  Kernel.stub(:sleep)
4
+ stub_const("Rainforest::Cli::API_URL", 'http://app.rainforest.dev/api/1')
4
5
  end
5
6
 
6
7
  describe ".start" do
7
8
  let(:valid_args) { %w(--token foo run --fg all) }
8
9
  let(:ok_progress) { {"state" => "in_progress", "current_progress" => {"percent" => "1"} } }
9
10
 
11
+ context "with bad parameters" do
12
+ context "with custom-url with no site-id" do
13
+ it 'errors out' do
14
+ expect(STDOUT).to receive(:puts).with('The site-id and custom-url options work together, you need both of them.')
15
+ begin
16
+ described_class.start(%w(--custom-url http://ad-hoc.example.com))
17
+ rescue SystemExit => e
18
+ # That's fine, this is expected but tested in a differnet assertion
19
+ end
20
+ end
21
+
22
+ it 'exits with exit code 1' do
23
+ expect {
24
+ described_class.start(%w(--custom-url http://ad-hoc.example.com))
25
+ }.to raise_error { |error|
26
+ expect(error).to be_a(SystemExit)
27
+ expect(error.status).to eq 1
28
+ }
29
+ end
30
+ end
31
+ end
32
+
33
+ context "with site-id and custom-url" do
34
+ it "creates a new environment" do
35
+ allow(described_class).to receive(:post).and_return { exit }
36
+ expect(described_class).to receive(:post).with(
37
+ "http://app.rainforest.dev/api/1/environments",
38
+ {
39
+ :name => "temporary-env-for-custom-url-via-CLI",
40
+ :url=>"http://ad-hoc.example.com"
41
+ }
42
+ ).and_return(
43
+ { 'id' => 333 }
44
+ )
45
+
46
+ # This is a hack because when expecting a function to be called with
47
+ # parameters, the last call is compared but I want to compare the first
48
+ # call, not the call to create a run, so I exit, but rescue from it here
49
+ # so that the spec doesn't fail. It's horrible, sorry!
50
+ begin
51
+ described_class.start(%w(--site 3 --custom-url http://ad-hoc.example.com))
52
+ rescue SystemExit => e
53
+ # That's fine, this is expected but tested in a differnet assertion
54
+ end
55
+ end
56
+
57
+ it "starts the run with site_id and environment_id" do
58
+ allow(described_class).to receive(:get_environment_id).and_return(333)
59
+
60
+ expect(described_class).to receive(:post).with(
61
+ "http://app.rainforest.dev/api/1/runs",
62
+ { :tests=>[], :site_id=>3, :gem_version=>"0.0.13", :environment_id=>333 }
63
+ ).and_return( {} )
64
+ described_class.start(%w(--site 3 --custom-url http://ad-hoc.example.com))
65
+ end
66
+ end
67
+
10
68
  context "a simple run" do
11
69
  before do
12
70
  described_class.stub(:post) { {"id" => 1} }
@@ -42,4 +100,34 @@ describe Rainforest::Cli do
42
100
  end
43
101
  end
44
102
  end
103
+
104
+ describe ".get_environment_id" do
105
+ context "with an invalid URL" do
106
+ it 'errors out and exits' do
107
+ expect(STDOUT).to receive(:puts).with("The custom URL is invalid")
108
+ expect {
109
+ described_class.get_environment_id('http://some=weird')
110
+ }.to raise_error { |error|
111
+ expect(error).to be_a(SystemExit)
112
+ expect(error.status).to eq 1
113
+ }
114
+ end
115
+ end
116
+
117
+ context 'on API error' do
118
+ before do
119
+ allow(described_class).to receive(:post).and_return( {"error"=>"Some API error"} )
120
+ end
121
+
122
+ it 'errors out and exits' do
123
+ expect(STDOUT).to receive(:puts).with("Error creating the ad-hoc URL: Some API error")
124
+ expect {
125
+ described_class.get_environment_id('http://example.com')
126
+ }.to raise_error { |error|
127
+ expect(error).to be_a(SystemExit)
128
+ expect(error.status).to eq 1
129
+ }
130
+ end
131
+ end
132
+ end
45
133
  end
data/spec/options_spec.rb CHANGED
@@ -61,4 +61,14 @@ describe Rainforest::Cli::OptionParser do
61
61
  let(:args) { ["run", "--fail-fast"] }
62
62
  its(:failfast?) { should be_true }
63
63
  end
64
+
65
+ context "it parses the site-id flag" do
66
+ let(:args) { ["run", "--site-id", '3'] }
67
+ its(:site_id) { should eq 3 }
68
+ end
69
+
70
+ context "it parses the custom-url flag" do
71
+ let(:args) { ["run", "--custom-url", 'http://ad-hoc.example.com'] }
72
+ its(:custom_url) { should eq 'http://ad-hoc.example.com' }
73
+ end
64
74
  end
data.tar.gz.sig CHANGED
@@ -1 +1,2 @@
1
- �?��̛��Ɛe��Q���H���} I�&O�Hf��A��b�z��V�: �[�����X�߬v���bu�����֬��gR�~��-"дja�0H6`5ާz$�8őP��p�+V[�xq��#)� ��E�J})$�up#�� �!��iս}XA*��� ��� N���l��h wͥ$k��r��i �u(��R���� ��ŗ{y�A�J�L�'���
1
+ Z��K�i�
2
+ �P3�W�wl������Yj����ߌR�
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: rainforest-cli
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.13
4
+ version: 0.0.14
5
5
  platform: ruby
6
6
  authors:
7
7
  - Simon Mathieu
@@ -32,7 +32,7 @@ cert_chain:
32
32
  wWdLLpBZZ1O4GE0uzQovmTiis4iyCF+8tFIgjbM/FVwKUBV6OZpxs4FOBtR1mK6L
33
33
  lj0cPcKRm/FZUw==
34
34
  -----END CERTIFICATE-----
35
- date: 2014-08-14 00:00:00.000000000 Z
35
+ date: 2014-09-08 00:00:00.000000000 Z
36
36
  dependencies:
37
37
  - !ruby/object:Gem::Dependency
38
38
  name: httparty
@@ -123,6 +123,7 @@ files:
123
123
  - README.md
124
124
  - Rakefile
125
125
  - bin/rainforest
126
+ - certs/ukd1.pem
126
127
  - lib/rainforest/cli.rb
127
128
  - lib/rainforest/cli/csv_importer.rb
128
129
  - lib/rainforest/cli/options.rb
metadata.gz.sig CHANGED
Binary file