diff options
author | Robert Speicher <rspeicher@gmail.com> | 2017-03-20 18:31:41 -0400 |
---|---|---|
committer | Robert Speicher <rspeicher@gmail.com> | 2017-03-20 20:45:32 -0400 |
commit | 8e53a9cba0092aeeb87011a51e71211a1e0ca0ff (patch) | |
tree | f5b4082355ad46d5ba8fcc2ea331bb388db1c6f8 /spec | |
parent | 9f98efa13c9cc718ce0a3ad540e54d88246ec9f7 (diff) | |
download | gitlab-ce-8e53a9cba0092aeeb87011a51e71211a1e0ca0ff.tar.gz |
WIP: Refactor cop with def_node_search
Makes it a simpler cop but maybe a bit more brittle?
Diffstat (limited to 'spec')
-rw-r--r-- | spec/rubocop/cop/security/to_json_spec.rb | 206 |
1 files changed, 77 insertions, 129 deletions
diff --git a/spec/rubocop/cop/security/to_json_spec.rb b/spec/rubocop/cop/security/to_json_spec.rb index 97ab3c60f65..bb9e4b57c95 100644 --- a/spec/rubocop/cop/security/to_json_spec.rb +++ b/spec/rubocop/cop/security/to_json_spec.rb @@ -11,64 +11,111 @@ describe RuboCop::Cop::Security::ToJson do subject(:cop) { described_class.new } it 'ignores calls except `to_json`' do - inspect_source(cop, "render text: 'Hello'") + inspect_source(cop, 'render json: foo') expect(cop.offenses).to be_empty end - context 'to_json with `include`' do - it 'adds an offense' do + context 'to_json with options' do + it 'does nothing when provided `only`' do + # s(:hash, + # s(:pair, + # s(:sym, :only), + # s(:array, + # s(:sym, :name), + # s(:sym, :username)))) inspect_source(cop, <<~EOS) - render json: issue.to_json( + render json: @issue.to_json(only: [:name, :username]) + EOS + + expect(cop.offenses).to be_empty + end + + it 'does nothing when provided `only` and `methods`' do + # s(:hash, + # s(:pair, + # s(:sym, :only), + # s(:array, + # s(:sym, :name), + # s(:sym, :username))), + # s(:pair, + # s(:sym, :methods), + # s(:array, + # s(:sym, :avatar_url)))) + inspect_source(cop, <<~EOS) + render json: @issue.to_json(only: [:name, :username], methods: [:avatar_url]) + EOS + + expect(cop.offenses).to be_empty + end + + it 'adds an offense to `include`d attributes without `only` option' do + # s(:hash, + # s(:pair, + # s(:sym, :include), + # s(:hash, + # s(:pair, + # s(:sym, :milestone), + # s(:hash)), + # s(:pair, + # s(:sym, :assignee), + # s(:hash, + # s(:pair, + # s(:sym, :methods), + # s(:sym, :avatar_url)))), + # s(:pair, + # s(:sym, :author), + # s(:hash, + # s(:pair, + # s(:sym, :only), + # s(:array, + # s(:str, "foo"), + # s(:str, "bar")))))))) + inspect_source(cop, <<~EOS) + render json: @issue.to_json( include: { milestone: {}, assignee: { methods: :avatar_url }, - labels: { methods: :text_color } - }, - methods: [:task_status, :task_status_short] + author: { only: %w[foo bar] }, + } ) EOS aggregate_failures do - expect(cop.offenses.size).to eq(3) + expect(cop.offenses.size).to eq(2) expect(cop.highlights).to contain_exactly( 'milestone: {}', - 'assignee: { methods: :avatar_url }', - 'labels: { methods: :text_color }' + 'assignee: { methods: :avatar_url }' ) end end - end - - context 'to_json without `include`' do - it 'does nothing when `only` is specified' do - source = %q(current_user.created_projects.where(import_type: "gitlab").to_json(only: [:id, :import_status])) - inspect_source(cop, source) + it 'adds an offense for `except`' do + inspect_source(cop, <<~EOS) + render json: @issue.to_json(except: [:private_token]) + EOS - expect(cop.offenses).to be_empty + aggregate_failures do + expect(cop.offenses.size).to eq(1) + expect(cop.highlights).to contain_exactly('except: [:private_token]') + end end - - # it 'adds an offense without `only`' do - # source = %q(current_user.created_projects.where(import_type: "gitlab").to_json(except: [:id, :import_status])) - # inspect_source(cop, source) - # - # aggregate_failures do - # expect(cop.offenses.size).to eq(1) - # expect(cop.highlights).to contain_exactly("except: [:id, :import_status]") - # end - # end end context 'to_json without options' do + it 'does nothing when called with nil receiver' do + inspect_source(cop, 'to_json') + + expect(cop.offenses).to be_empty + end it 'does nothing when called directly on a Hash' do - inspect_source(cop, "{}.to_json") + inspect_source(cop, '{}.to_json') expect(cop.offenses).to be_empty end - it 'adds an offense when called on object' do - inspect_source(cop, "foo.to_json") + it 'adds an offense when called on variable' do + inspect_source(cop, 'foo.to_json') aggregate_failures do expect(cop.offenses.size).to eq(1) @@ -76,103 +123,4 @@ describe RuboCop::Cop::Security::ToJson do end end end - - # context 'when a class has a body' do - # it 'does nothing' do - # inspect_source(cop, 'class CustomError < StandardError; def foo; end; end') - # - # expect(cop.offenses).to be_empty - # end - # end - # - # context 'when a class has no explicit superclass' do - # it 'does nothing' do - # inspect_source(cop, 'class CustomError; end') - # - # expect(cop.offenses).to be_empty - # end - # end - # - # context 'when a class has a superclass that does not end in Error' do - # it 'does nothing' do - # inspect_source(cop, 'class CustomError < BasicObject; end') - # - # expect(cop.offenses).to be_empty - # end - # end - # - # context 'when a class is empty and inherits from a class ending in Error' do - # context 'when the class is on a single line' do - # let(:source) do - # <<-SOURCE - # module Foo - # class CustomError < Bar::Baz::BaseError; end - # end - # SOURCE - # end - # - # let(:expected) do - # <<-EXPECTED - # module Foo - # CustomError = Class.new(Bar::Baz::BaseError) - # end - # EXPECTED - # end - # - # it 'registers an offense' do - # expected_highlights = source.split("\n")[1].strip - # - # inspect_source(cop, source) - # - # aggregate_failures do - # expect(cop.offenses.size).to eq(1) - # expect(cop.offenses.map(&:line)).to eq([2]) - # expect(cop.highlights).to contain_exactly(expected_highlights) - # end - # end - # - # it 'autocorrects to the right version' do - # autocorrected = autocorrect_source(cop, source, 'foo/custom_error.rb') - # - # expect(autocorrected).to eq(expected) - # end - # end - # - # context 'when the class is on multiple lines' do - # let(:source) do - # <<-SOURCE - # module Foo - # class CustomError < Bar::Baz::BaseError - # end - # end - # SOURCE - # end - # - # let(:expected) do - # <<-EXPECTED - # module Foo - # CustomError = Class.new(Bar::Baz::BaseError) - # end - # EXPECTED - # end - # - # it 'registers an offense' do - # expected_highlights = source.split("\n")[1..2].join("\n").strip - # - # inspect_source(cop, source) - # - # aggregate_failures do - # expect(cop.offenses.size).to eq(1) - # expect(cop.offenses.map(&:line)).to eq([2]) - # expect(cop.highlights).to contain_exactly(expected_highlights) - # end - # end - # - # it 'autocorrects to the right version' do - # autocorrected = autocorrect_source(cop, source, 'foo/custom_error.rb') - # - # expect(autocorrected).to eq(expected) - # end - # end - # end end |