diff options
author | Nick Thomas <nick@gitlab.com> | 2019-07-01 16:48:49 +0000 |
---|---|---|
committer | Nick Thomas <nick@gitlab.com> | 2019-07-01 16:48:49 +0000 |
commit | 402255c290e4bb96386bc1ff3fd8c4f10669f6b2 (patch) | |
tree | 6865fd63f69c18bc316b78cd43917a32b79a69b4 /spec | |
parent | 01a978593952456f8ff97cc3d415b3dfc5e421e8 (diff) | |
parent | dae02286ba942d3783ff13c4f74f34f72d20b68d (diff) | |
download | gitlab-ce-402255c290e4bb96386bc1ff3fd8c4f10669f6b2.tar.gz |
Merge branch '9491-graphql-view-design-board-at-version-ce' into 'master'
CE backport for "Show design boards at previous versions in GraphQL"
See merge request gitlab-org/gitlab-ce!30151
Diffstat (limited to 'spec')
-rw-r--r-- | spec/lib/gitlab/graphql/find_argument_in_parent_spec.rb | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/spec/lib/gitlab/graphql/find_argument_in_parent_spec.rb b/spec/lib/gitlab/graphql/find_argument_in_parent_spec.rb new file mode 100644 index 00000000000..91e90315b3e --- /dev/null +++ b/spec/lib/gitlab/graphql/find_argument_in_parent_spec.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe Gitlab::Graphql::FindArgumentInParent do + describe '#find' do + def build_node(parent = nil, args: {}) + props = { irep_node: double(arguments: args) } + props[:parent] = parent if parent # The root node shouldn't respond to parent + + double(props) + end + + let(:parent) do + build_node( + build_node( + build_node( + build_node, + args: { myArg: 1 } + ) + ) + ) + end + let(:arg_name) { :my_arg } + + it 'searches parents and returns the argument' do + expect(described_class.find(parent, :my_arg)).to eq(1) + end + + it 'can find argument when passed in as both Ruby and GraphQL-formatted symbols and strings' do + [:my_arg, :myArg, 'my_arg', 'myArg'].each do |arg| + expect(described_class.find(parent, arg)).to eq(1) + end + end + + it 'returns nil if no arguments found in parents' do + expect(described_class.find(parent, :bar)).to eq(nil) + end + + it 'can limit the depth it searches to' do + expect(described_class.find(parent, :my_arg, limit_depth: 1)).to eq(nil) + end + end +end |