describe KnapsackPro::Config::Env do before { stub_const("ENV", {}) } describe '.ci_node_total' do subject { described_class.ci_node_total } context 'when ENV exists' do context 'when KNAPSACK_PRO_CI_NODE_TOTAL has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_CI_NODE_TOTAL' => '5' }) } it { should eq 5 } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:node_total).and_return(4) end it { should eq 4 } end end context "when ENV doesn't exist" do it { should eq 1 } end end describe '.ci_node_index' do subject { described_class.ci_node_index } context 'when ENV exists' do context 'when KNAPSACK_PRO_CI_NODE_INDEX has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_CI_NODE_INDEX' => '3' }) } it { should eq 3 } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:node_index).and_return(2) end it { should eq 2 } end end context "when ENV doesn't exist" do it { should eq 0 } end end describe '.ci_node_build_id' do subject { described_class.ci_node_build_id } context 'when ENV exists' do context 'when KNAPSACK_PRO_CI_NODE_BUILD_ID has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_CI_NODE_BUILD_ID' => '7' }) } it { should eq '7' } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:node_build_id).and_return('8') end it { should eq '8' } end end context "when ENV doesn't exist" do it { should eq 'missing-build-id' } end end describe '.commit_hash' do subject { described_class.commit_hash } context 'when ENV exists' do context 'when KNAPSACK_PRO_COMMIT_HASH has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_COMMIT_HASH' => '3fa64859337f6e56409d49f865d13fd7' }) } it { should eq '3fa64859337f6e56409d49f865d13fd7' } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:commit_hash).and_return('fe61a08118d0d52e97c38666eba1eaf3') end it { should eq 'fe61a08118d0d52e97c38666eba1eaf3' } end end context "when ENV doesn't exist" do it { should be nil } end end describe '.branch' do subject { described_class.branch } context 'when ENV exists' do context 'when KNAPSACK_PRO_BRANCH has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_BRANCH' => 'master' }) } it { should eq 'master' } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:branch).and_return('feature-branch') end it { should eq 'feature-branch' } end end context "when ENV doesn't exist" do it { should be nil } end end describe '.project_dir' do subject { described_class.project_dir } context 'when ENV exists' do context 'when KNAPSACK_PRO_PROJECT_DIR has value' do before { stub_const("ENV", { 'KNAPSACK_PRO_PROJECT_DIR' => '/home/user/myapp' }) } it { should eq '/home/user/myapp' } end context 'when CI environment has value' do before do expect(described_class).to receive(:ci_env_for).with(:project_dir).and_return('/home/runner/myapp') end it { should eq '/home/runner/myapp' } end end context "when ENV doesn't exist" do it { should be nil } end end describe '.test_file_pattern' do subject { described_class.test_file_pattern } context 'when ENV exists' do let(:test_file_pattern) { 'custom_spec/**{,/*/**}/*_spec.rb' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_FILE_PATTERN' => test_file_pattern }) } it { should eq test_file_pattern } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_dir' do subject { described_class.test_dir } context 'when ENV exists' do let(:test_dir) { 'spec' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_DIR' => test_dir }) } it { should eql test_dir } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.repository_adapter' do subject { described_class.repository_adapter } context 'when ENV exists' do let(:repository_adapter) { 'git' } before { stub_const("ENV", { 'KNAPSACK_PRO_REPOSITORY_ADAPTER' => repository_adapter }) } it { should eq repository_adapter } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.recording_enabled' do subject { described_class.recording_enabled } context 'when ENV exists' do let(:recording_enabled) { 'true' } before { stub_const("ENV", { 'KNAPSACK_PRO_RECORDING_ENABLED' => recording_enabled }) } it { should eq recording_enabled } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.recording_enabled?' do subject { described_class.recording_enabled? } before do expect(described_class).to receive(:recording_enabled).and_return(recording_enabled) end context 'when enabled' do let(:recording_enabled) { 'true' } it { should be true } end context 'when disabled' do let(:recording_enabled) { nil } it { should be false } end end describe '.queue_recording_enabled' do subject { described_class.queue_recording_enabled } context 'when ENV exists' do let(:queue_recording_enabled) { 'true' } before { stub_const("ENV", { 'KNAPSACK_PRO_QUEUE_RECORDING_ENABLED' => queue_recording_enabled }) } it { should eq queue_recording_enabled } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.queue_recording_enabled?' do subject { described_class.queue_recording_enabled? } before do expect(described_class).to receive(:queue_recording_enabled).and_return(queue_recording_enabled) end context 'when enabled' do let(:queue_recording_enabled) { 'true' } it { should be true } end context 'when disabled' do let(:queue_recording_enabled) { nil } it { should be false } end end describe '.queue_id' do subject { described_class.queue_id } context 'when ENV exists' do let(:queue_id) { 'fake-queue-id' } before { stub_const("ENV", { 'KNAPSACK_PRO_QUEUE_ID' => queue_id }) } it { should eq queue_id } end context "when ENV doesn't exist" do before { stub_const("ENV", {}) } it do expect { subject }.to raise_error('Missing Queue ID') end end end describe '.subset_queue_id' do subject { described_class.subset_queue_id } context 'when ENV exists' do let(:subset_queue_id) { 'fake-subset-queue-id' } before { stub_const("ENV", { 'KNAPSACK_PRO_SUBSET_QUEUE_ID' => subset_queue_id }) } it { should eq subset_queue_id } end context "when ENV doesn't exist" do it do expect { subject }.to raise_error('Missing Subset Queue ID') end end end describe '.test_files_encrypted' do subject { described_class.test_files_encrypted } context 'when ENV exists' do let(:test_files_encrypted) { 'true' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_FILES_ENCRYPTED' => test_files_encrypted }) } it { should eq test_files_encrypted } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_files_encrypted?' do subject { described_class.test_files_encrypted? } before do expect(described_class).to receive(:test_files_encrypted).and_return(test_files_encrypted) end context 'when enabled' do let(:test_files_encrypted) { 'true' } it { should be true } end context 'when disabled' do let(:test_files_encrypted) { nil } it { should be false } end end describe '.modify_default_rspec_formatters' do subject { described_class.modify_default_rspec_formatters } context 'when ENV exists' do let(:modify_default_rspec_formatters) { 'false' } before { stub_const("ENV", { 'KNAPSACK_PRO_MODIFY_DEFAULT_RSPEC_FORMATTERS' => modify_default_rspec_formatters }) } it { should eq modify_default_rspec_formatters } end context "when ENV doesn't exist" do it { should be true } end end describe '.modify_default_rspec_formatters?' do subject { described_class.modify_default_rspec_formatters? } before do expect(described_class).to receive(:modify_default_rspec_formatters).and_return(modify_default_rspec_formatters) end context 'when enabled' do let(:modify_default_rspec_formatters) { true } it { should be true } end context 'when disabled' do let(:modify_default_rspec_formatters) { false } it { should be false } end end describe '.branch_encrypted' do subject { described_class.branch_encrypted } context 'when ENV exists' do let(:branch_encrypted) { 'true' } before { stub_const("ENV", { 'KNAPSACK_PRO_BRANCH_ENCRYPTED' => branch_encrypted }) } it { should eq branch_encrypted } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.branch_encrypted?' do subject { described_class.branch_encrypted? } before do expect(described_class).to receive(:branch_encrypted).and_return(branch_encrypted) end context 'when enabled' do let(:branch_encrypted) { 'true' } it { should be true } end context 'when disabled' do let(:branch_encrypted) { nil } it { should be false } end end describe '.salt' do subject { described_class.salt } context 'when ENV exists' do let(:salt) { '123' } before { stub_const("ENV", { 'KNAPSACK_PRO_SALT' => salt }) } it { should eq salt } end context "when ENV doesn't exist" do it do expect { subject }.to raise_error('Missing environment variable KNAPSACK_PRO_SALT') end end end describe '.endpoint' do subject { described_class.endpoint } context 'when ENV exists' do let(:endpoint) { 'http://api-custom-url.knapsackpro.com' } before { stub_const("ENV", { 'KNAPSACK_PRO_ENDPOINT' => endpoint }) } it { should eq endpoint } end context "when ENV doesn't exist" do context 'when default mode' do it { should eq 'https://api.knapsackpro.com' } end context 'when development mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'development' }) } it { should eq 'http://api.knapsackpro.dev:3000' } end context 'when test mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'test' }) } it { should eq 'https://api-staging.knapsackpro.com' } end context 'when production mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'production' }) } it { should eq 'https://api.knapsackpro.com' } end context 'when unknown mode' do before do expect(described_class).to receive(:mode).and_return(:fake) end it do expect { subject }.to raise_error('Missing environment variable KNAPSACK_PRO_ENDPOINT') end end end end describe '.fixed_test_suite_split' do subject { described_class.fixed_test_suite_split } context 'when ENV exists' do before { stub_const("ENV", { 'KNAPSACK_PRO_FIXED_TEST_SUITE_SPLIT' => false }) } it { should eq false } end context "when ENV doesn't exist" do before { stub_const("ENV", {}) } it { should be true } end end describe '.fixed_queue_split' do subject { described_class.fixed_queue_split } context 'when ENV exists' do before { stub_const("ENV", { 'KNAPSACK_PRO_FIXED_QUEUE_SPLIT' => true }) } it { should eq true } end context "when ENV doesn't exist" do before { stub_const("ENV", {}) } it { should be false } end end describe '.test_suite_token' do subject { described_class.test_suite_token } context 'when ENV exists' do let(:token) { 'xyz' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN' => 'xyz' }) } it { should eq token } end context "when ENV doesn't exist" do it do expect { subject }.to raise_error('Missing environment variable KNAPSACK_PRO_TEST_SUITE_TOKEN. You should set environment variable like KNAPSACK_PRO_TEST_SUITE_TOKEN_RSPEC (note there is suffix _RSPEC at the end). knapsack_pro gem will set KNAPSACK_PRO_TEST_SUITE_TOKEN based on KNAPSACK_PRO_TEST_SUITE_TOKEN_RSPEC value. If you use other test runner than RSpec then use proper suffix.') end end end describe '.test_suite_token_rspec' do subject { described_class.test_suite_token_rspec } context 'when ENV exists' do let(:test_suite_token_rspec) { 'rspec-token' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN_RSPEC' => test_suite_token_rspec }) } it { should eq test_suite_token_rspec } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_suite_token_minitest' do subject { described_class.test_suite_token_minitest } context 'when ENV exists' do let(:test_suite_token_minitest) { 'minitest-token' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN_MINITEST' => test_suite_token_minitest }) } it { should eq test_suite_token_minitest } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_suite_token_test_unit' do subject { described_class.test_suite_token_test_unit } context 'when ENV exists' do let(:test_suite_token_test_unit) { 'test-unit-token' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN_TEST_UNIT' => test_suite_token_test_unit }) } it { should eq test_suite_token_test_unit } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_suite_token_cucumber' do subject { described_class.test_suite_token_cucumber } context 'when ENV exists' do let(:test_suite_token_cucumber) { 'cucumber-token' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN_CUCUMBER' => test_suite_token_cucumber }) } it { should eq test_suite_token_cucumber } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.test_suite_token_spinach' do subject { described_class.test_suite_token_spinach } context 'when ENV exists' do let(:test_suite_token_spinach) { 'spinach-token' } before { stub_const("ENV", { 'KNAPSACK_PRO_TEST_SUITE_TOKEN_SPINACH' => test_suite_token_spinach }) } it { should eq test_suite_token_spinach } end context "when ENV doesn't exist" do it { should be_nil } end end describe '.mode' do subject { described_class.mode } context 'when ENV exists' do context 'when development mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'development' }) } it { should eq :development } end context 'when test mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'test' }) } it { should eq :test } end context 'when production mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'production' }) } it { should eq :production } end context 'when fake mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => 'fake' }) } it do expect { subject }.to raise_error(ArgumentError) end end context 'when blank mode' do before { stub_const("ENV", { 'KNAPSACK_PRO_MODE' => '' }) } it do expect { subject }.to raise_error(ArgumentError) end end end context "when ENV doesn't exist" do it { should eq :production } end end describe '.ci_env_for' do let(:env_name) { :node_total } subject { described_class.ci_env_for(env_name) } context 'when CI has no value for env_name method' do before do expect(KnapsackPro::Config::CI::Circle).to receive_message_chain(:new, env_name).and_return(nil) expect(KnapsackPro::Config::CI::Semaphore).to receive_message_chain(:new, env_name).and_return(nil) expect(KnapsackPro::Config::CI::Buildkite).to receive_message_chain(:new, env_name).and_return(nil) end it do expect(subject).to be_nil end end context 'when CI has value for env_name method' do let(:circle_env) { double(:circle) } let(:semaphore_env) { double(:semaphore) } let(:buildkite_env) { double(:buildkite) } before do allow(KnapsackPro::Config::CI::Circle).to receive_message_chain(:new, env_name).and_return(circle_env) allow(KnapsackPro::Config::CI::Semaphore).to receive_message_chain(:new, env_name).and_return(semaphore_env) allow(KnapsackPro::Config::CI::Buildkite).to receive_message_chain(:new, env_name).and_return(buildkite_env) end it { should eq circle_env } context do let(:circle_env) { nil } it { should eq semaphore_env } end context do let(:circle_env) { nil } let(:semaphore_env) { nil } it { should eq buildkite_env } end end end describe '.log_level' do subject { described_class.log_level } context 'when ENV set to fatal' do let(:log_level) { 'fatal' } before { stub_const('ENV', { 'KNAPSACK_PRO_LOG_LEVEL' => log_level }) } it { should eql ::Logger::FATAL } end context 'when ENV set to error' do let(:log_level) { 'error' } before { stub_const('ENV', { 'KNAPSACK_PRO_LOG_LEVEL' => log_level }) } it { should eql ::Logger::ERROR } end context 'when ENV set to warn' do let(:log_level) { 'warn' } before { stub_const('ENV', { 'KNAPSACK_PRO_LOG_LEVEL' => log_level }) } it { should eql ::Logger::WARN } end context 'when ENV set to info' do let(:log_level) { 'info' } before { stub_const('ENV', { 'KNAPSACK_PRO_LOG_LEVEL' => log_level }) } it { should eql ::Logger::INFO } end context 'when ENV set with capital letters' do let(:log_level) { 'WARN' } before { stub_const('ENV', { 'KNAPSACK_PRO_LOG_LEVEL' => log_level }) } it { should eql ::Logger::WARN } end context "when ENV doesn't exist" do it { should eql ::Logger::DEBUG } end end end