require 'spec_helper' 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(:token) { Travis::Api::App::AccessToken.create(user: repo.owner, app_id: 1) } 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(:json_headers) { { 'CONTENT_TYPE' => 'application/json' } } describe 'not authenticated' do before { patch("/v3/repo/#{repo.id}/env_var/#{env_var[:id]}") } include_examples 'not authenticated' end describe 'authenticated, missing repo' do before { patch("/v3/repo/999999999/env_var/#{env_var[:id]}", {}, auth_headers) } include_examples 'missing repo' end describe 'authenticated, existing repo, missing env var' do before { patch("/v3/repo/#{repo.id}/env_var/foo", {}, auth_headers) } include_examples 'missing env_var' end describe 'authenticated, existing repo, existing env var' do let(:params) do { 'env_var.name' => 'QUX' } end before do repo.update_attributes(settings: JSON.generate(env_vars: [env_var])) patch("/v3/repo/#{repo.id}/env_var/#{env_var[:id]}", JSON.generate(params), auth_headers.merge(json_headers)) end example { expect(last_response.status).to eq 200 } example do expect(JSON.load(body)).to eq( '@type' => 'env_var', '@href' => '/v3/repo/1/env_var/abc', '@representation' => 'standard', 'id' => env_var[:id], 'name' => params['env_var.name'], 'value' => env_var[:value].decrypt, 'public' => env_var[:public] ) end end end