decrypt the public values for return and fix the tests

This commit is contained in:
Renée Hendricksen 2016-07-14 17:24:49 -04:00
parent 35ae19c3a0
commit 58cd17158c
6 changed files with 55 additions and 28 deletions

View File

@ -49,7 +49,7 @@ module Travis::API::V3
when Model then render_model(value, **options) when Model then render_model(value, **options)
when ActiveRecord::Relation then render_value(value.to_a, **options) when ActiveRecord::Relation then render_value(value.to_a, **options)
when ActiveRecord::Associations::CollectionProxy then render_value(value.to_a, **options) when ActiveRecord::Associations::CollectionProxy then render_value(value.to_a, **options)
when Travis::Settings::EncryptedValue then value # Should this be value.decrypt ?? If so do we want to add if options[:included].first.public? so we ensure we only decrypt public values? when Travis::Settings::EncryptedValue then value.decrypt
else raise ArgumentError, 'cannot render %p (%p)' % [value.class, value] else raise ArgumentError, 'cannot render %p (%p)' % [value.class, value]
end end
end end

View File

@ -3,7 +3,7 @@ require 'spec_helper'
describe Travis::API::V3::Services::EnvVar::Delete, set_app: true do describe Travis::API::V3::Services::EnvVar::Delete, set_app: true do
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create } let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create }
let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) }
let(:env_var) { { id: 'abc', name: 'FOO', value: 'bar', public: true, repository_id: repo.id } } let(:env_var) { { id: 'abc', name: 'FOO', value: Travis::Settings::EncryptedValue.new('bar'), public: true, repository_id: repo.id } }
let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } } let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } }
describe 'not authenticated' do describe 'not authenticated' do

View File

@ -3,7 +3,7 @@ require 'spec_helper'
describe Travis::API::V3::Services::EnvVar::Find, set_app: true do describe Travis::API::V3::Services::EnvVar::Find, set_app: true do
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create } let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create }
let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) }
let(:env_var) { { id: 'abc', name: 'FOO', value: 'bar', public: true, repository_id: repo.id } } let(:env_var) { { id: 'abc', name: 'FOO', value: Travis::Settings::EncryptedValue.new('bar'), public: true, repository_id: repo.id } }
let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } } let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } }
describe 'not authenticated' do describe 'not authenticated' do
@ -36,7 +36,7 @@ describe Travis::API::V3::Services::EnvVar::Find, set_app: true do
'id' => env_var[:id], 'id' => env_var[:id],
'name' => env_var[:name], 'name' => env_var[:name],
'public' => env_var[:public], 'public' => env_var[:public],
'value' => env_var[:value] 'value' => env_var[:value].decrypt
) )
end end
end end

View File

@ -3,7 +3,7 @@ require 'spec_helper'
describe Travis::API::V3::Services::EnvVar::Update, set_app: true do describe Travis::API::V3::Services::EnvVar::Update, set_app: true do
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create } let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create }
let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) }
let(:env_var) { { id: 'abc', name: 'FOO', value: 'bar', public: true, repository_id: repo.id } } let(:env_var) { { id: 'abc', name: 'FOO', value: Travis::Settings::EncryptedValue.new('bar'), public: true, repository_id: repo.id } }
let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } } let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } }
let(:json_headers) { { 'CONTENT_TYPE' => 'application/json' } } let(:json_headers) { { 'CONTENT_TYPE' => 'application/json' } }
@ -42,7 +42,7 @@ describe Travis::API::V3::Services::EnvVar::Update, set_app: true do
'@representation' => 'standard', '@representation' => 'standard',
'id' => env_var[:id], 'id' => env_var[:id],
'name' => params['env_var.name'], 'name' => params['env_var.name'],
'value' => env_var[:value], 'value' => env_var[:value].decrypt,
'public' => env_var[:public] 'public' => env_var[:public]
) )
end end

View File

@ -26,7 +26,7 @@ describe Travis::API::V3::Services::EnvVars::Create, set_app: true do
end end
before do before do
repo.update_attributes(settings: JSON.generate(env_vars: [{ id: 'abc', name: 'FOO', value: 'bar', public: false }])) repo.update_attributes(settings: JSON.generate(env_vars: [{ id: 'abc', name: 'FOO', value: Travis::Settings::EncryptedValue.new('bar'), public: false }]))
post("/v3/repo/#{repo.id}/env_vars", JSON.generate(params), auth_headers.merge(json_headers)) post("/v3/repo/#{repo.id}/env_vars", JSON.generate(params), auth_headers.merge(json_headers))
end end
@ -41,26 +41,53 @@ describe Travis::API::V3::Services::EnvVars::Create, set_app: true do
end end
describe 'authenticated, existing repo, env var is new' do describe 'authenticated, existing repo, env var is new' do
let(:params) do describe 'private' do
{ let(:params) do
'env_var.name' => 'FOO', {
'env_var.value' => 'bar', 'env_var.name' => 'FOO',
'env_var.public' => false 'env_var.value' => 'bar',
} 'env_var.public' => false
}
end
before { post("/v3/repo/#{repo.id}/env_vars", JSON.generate(params), auth_headers.merge(json_headers)) }
example { expect(last_response.status).to eq 201 }
example do
response = JSON.load(body)
expect(response).to include(
'@type' => 'env_var',
'@representation' => 'standard',
'name' => 'FOO',
'public' => false
)
expect(response).to include('@href', 'id')
end
end end
before { post("/v3/repo/#{repo.id}/env_vars", JSON.generate(params), auth_headers.merge(json_headers)) } describe 'public' do
let(:params) do
{
'env_var.name' => 'FOO',
'env_var.value' => 'bar',
'env_var.public' => true
}
end
example { expect(last_response.status).to eq 201 } before { post("/v3/repo/#{repo.id}/env_vars", JSON.generate(params), auth_headers.merge(json_headers)) }
example do
response = JSON.load(body) example { expect(last_response.status).to eq 201 }
expect(response).to include( example do
'@type' => 'env_var', response = JSON.load(body)
'@representation' => 'standard', expect(response).to include(
'name' => 'FOO', '@type' => 'env_var',
'public' => false '@representation' => 'standard',
) 'name' => 'FOO',
expect(response).to include('@href', 'id') 'value' => 'bar',
'public' => true
)
expect(response).to include('@href', 'id')
end
end end
end end
end end

View File

@ -3,7 +3,7 @@ require 'spec_helper'
describe Travis::API::V3::Services::EnvVars::ForRepository, set_app: true do describe Travis::API::V3::Services::EnvVars::ForRepository, set_app: true do
let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create } let(:repo) { Travis::API::V3::Models::Repository.where(owner_name: 'svenfuchs', name: 'minimal').first_or_create }
let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } let(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) }
let(:env_var) { { id: 'abc', name: 'FOO', value: 'bar', public: true, repository_id: repo.id } } let(:env_var) { { id: 'abc', name: 'FOO', value: Travis::Settings::EncryptedValue.new('bar'), public: true, repository_id: repo.id } }
let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } } let(:auth_headers) { { 'HTTP_AUTHORIZATION' => "token #{token}" } }
describe 'not authenticated' do describe 'not authenticated' do
@ -49,7 +49,7 @@ describe Travis::API::V3::Services::EnvVars::ForRepository, set_app: true do
'@representation' => 'standard', '@representation' => 'standard',
'id' => env_var[:id], 'id' => env_var[:id],
'name' => env_var[:name], 'name' => env_var[:name],
'value' => env_var[:value], 'value' => env_var[:value].decrypt,
'public' => env_var[:public] 'public' => env_var[:public]
} }
] ]