chewy 0.8.4 → 0.9.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.rubocop.yml +34 -0
- data/.rubocop_todo.yml +44 -0
- data/.travis.yml +20 -60
- data/Appraisals +15 -40
- data/CHANGELOG.md +42 -0
- data/Gemfile +1 -0
- data/Guardfile +5 -5
- data/README.md +155 -6
- data/Rakefile +11 -1
- data/chewy.gemspec +5 -7
- data/gemfiles/rails.3.2.activerecord.gemfile +1 -0
- data/gemfiles/rails.3.2.activerecord.kaminari.gemfile +1 -0
- data/gemfiles/rails.3.2.activerecord.will_paginate.gemfile +1 -0
- data/gemfiles/rails.4.2.activerecord.gemfile +1 -0
- data/gemfiles/rails.4.2.activerecord.kaminari.gemfile +1 -0
- data/gemfiles/rails.4.2.activerecord.will_paginate.gemfile +1 -0
- data/gemfiles/{rails.4.2.mongoid.4.0.0.gemfile → rails.4.2.mongoid.4.0.gemfile} +2 -1
- data/gemfiles/{rails.4.2.mongoid.4.0.0.kaminari.gemfile → rails.4.2.mongoid.4.0.kaminari.gemfile} +2 -1
- data/gemfiles/{rails.4.2.mongoid.4.0.0.will_paginate.gemfile → rails.4.2.mongoid.4.0.will_paginate.gemfile} +2 -1
- data/gemfiles/{rails.4.2.mongoid.5.1.0.gemfile → rails.4.2.mongoid.5.1.gemfile} +2 -1
- data/gemfiles/{rails.4.2.mongoid.5.1.0.kaminari.gemfile → rails.4.2.mongoid.5.1.kaminari.gemfile} +2 -1
- data/gemfiles/{rails.4.2.mongoid.5.1.0.will_paginate.gemfile → rails.4.2.mongoid.5.1.will_paginate.gemfile} +2 -1
- data/gemfiles/{rails.4.0.activerecord.gemfile → rails.5.0.activerecord.gemfile} +4 -2
- data/gemfiles/{rails.4.0.mongoid.4.0.0.kaminari.gemfile → rails.5.0.activerecord.kaminari.gemfile} +4 -2
- data/gemfiles/{rails.4.0.mongoid.4.0.0.will_paginate.gemfile → rails.5.0.activerecord.will_paginate.gemfile} +4 -2
- data/gemfiles/{sequel.4.31.gemfile → sequel.4.38.gemfile} +3 -2
- data/lib/chewy.rb +24 -16
- data/lib/chewy/backports/deep_dup.rb +1 -1
- data/lib/chewy/backports/duplicable.rb +1 -0
- data/lib/chewy/config.rb +13 -7
- data/lib/chewy/errors.rb +4 -4
- data/lib/chewy/fields/base.rb +19 -14
- data/lib/chewy/fields/root.rb +11 -9
- data/lib/chewy/index.rb +38 -25
- data/lib/chewy/index/actions.rb +17 -17
- data/lib/chewy/index/settings.rb +3 -4
- data/lib/chewy/journal.rb +107 -0
- data/lib/chewy/journal/apply.rb +31 -0
- data/lib/chewy/journal/clean.rb +24 -0
- data/lib/chewy/journal/entry.rb +83 -0
- data/lib/chewy/journal/query.rb +87 -0
- data/lib/chewy/log_subscriber.rb +8 -8
- data/lib/chewy/minitest.rb +1 -0
- data/lib/chewy/minitest/helpers.rb +77 -0
- data/lib/chewy/minitest/search_index_receiver.rb +80 -0
- data/lib/chewy/query.rb +116 -60
- data/lib/chewy/query/compose.rb +5 -6
- data/lib/chewy/query/criteria.rb +26 -16
- data/lib/chewy/query/filters.rb +9 -9
- data/lib/chewy/query/loading.rb +2 -2
- data/lib/chewy/query/nodes/and.rb +3 -3
- data/lib/chewy/query/nodes/base.rb +1 -1
- data/lib/chewy/query/nodes/bool.rb +6 -4
- data/lib/chewy/query/nodes/equal.rb +6 -6
- data/lib/chewy/query/nodes/exists.rb +2 -2
- data/lib/chewy/query/nodes/expr.rb +2 -2
- data/lib/chewy/query/nodes/field.rb +35 -31
- data/lib/chewy/query/nodes/has_child.rb +1 -0
- data/lib/chewy/query/nodes/has_parent.rb +1 -0
- data/lib/chewy/query/nodes/has_relation.rb +11 -13
- data/lib/chewy/query/nodes/match_all.rb +1 -1
- data/lib/chewy/query/nodes/missing.rb +2 -2
- data/lib/chewy/query/nodes/not.rb +3 -3
- data/lib/chewy/query/nodes/or.rb +3 -3
- data/lib/chewy/query/nodes/prefix.rb +4 -3
- data/lib/chewy/query/nodes/query.rb +3 -3
- data/lib/chewy/query/nodes/range.rb +11 -11
- data/lib/chewy/query/nodes/raw.rb +1 -1
- data/lib/chewy/query/nodes/regexp.rb +15 -11
- data/lib/chewy/query/nodes/script.rb +6 -6
- data/lib/chewy/query/pagination/will_paginate.rb +2 -2
- data/lib/chewy/railtie.rb +3 -3
- data/lib/chewy/rake_helper.rb +51 -30
- data/lib/chewy/repository.rb +2 -2
- data/lib/chewy/rspec.rb +1 -1
- data/lib/chewy/rspec/update_index.rb +46 -47
- data/lib/chewy/runtime/version.rb +4 -4
- data/lib/chewy/search.rb +7 -5
- data/lib/chewy/strategy.rb +10 -8
- data/lib/chewy/strategy/atomic.rb +2 -2
- data/lib/chewy/strategy/base.rb +4 -4
- data/lib/chewy/strategy/bypass.rb +1 -2
- data/lib/chewy/strategy/sidekiq.rb +2 -0
- data/lib/chewy/strategy/urgent.rb +1 -1
- data/lib/chewy/type.rb +51 -45
- data/lib/chewy/type/adapter/active_record.rb +23 -12
- data/lib/chewy/type/adapter/base.rb +4 -4
- data/lib/chewy/type/adapter/mongoid.rb +6 -6
- data/lib/chewy/type/adapter/object.rb +15 -12
- data/lib/chewy/type/adapter/orm.rb +24 -15
- data/lib/chewy/type/adapter/sequel.rb +11 -7
- data/lib/chewy/type/crutch.rb +4 -3
- data/lib/chewy/type/import.rb +51 -32
- data/lib/chewy/type/mapping.rb +17 -17
- data/lib/chewy/type/observe.rb +9 -7
- data/lib/chewy/type/witchcraft.rb +62 -23
- data/lib/chewy/type/wrapper.rb +20 -14
- data/lib/chewy/version.rb +1 -1
- data/lib/generators/chewy/install_generator.rb +3 -3
- data/lib/tasks/chewy.rake +28 -23
- data/spec/chewy/config_spec.rb +33 -12
- data/spec/chewy/fields/base_spec.rb +143 -154
- data/spec/chewy/fields/root_spec.rb +22 -20
- data/spec/chewy/fields/time_fields_spec.rb +11 -9
- data/spec/chewy/index/actions_spec.rb +27 -4
- data/spec/chewy/index/aliases_spec.rb +2 -2
- data/spec/chewy/index/settings_spec.rb +72 -50
- data/spec/chewy/index_spec.rb +95 -43
- data/spec/chewy/journal/apply_spec.rb +120 -0
- data/spec/chewy/journal/entry_spec.rb +237 -0
- data/spec/chewy/journal_spec.rb +173 -0
- data/spec/chewy/minitest/helpers_spec.rb +90 -0
- data/spec/chewy/minitest/search_index_receiver_spec.rb +120 -0
- data/spec/chewy/query/criteria_spec.rb +504 -237
- data/spec/chewy/query/filters_spec.rb +94 -66
- data/spec/chewy/query/loading_spec.rb +76 -40
- data/spec/chewy/query/nodes/and_spec.rb +3 -7
- data/spec/chewy/query/nodes/bool_spec.rb +5 -13
- data/spec/chewy/query/nodes/equal_spec.rb +20 -20
- data/spec/chewy/query/nodes/exists_spec.rb +7 -7
- data/spec/chewy/query/nodes/has_child_spec.rb +42 -23
- data/spec/chewy/query/nodes/has_parent_spec.rb +42 -23
- data/spec/chewy/query/nodes/match_all_spec.rb +2 -2
- data/spec/chewy/query/nodes/missing_spec.rb +6 -5
- data/spec/chewy/query/nodes/not_spec.rb +3 -7
- data/spec/chewy/query/nodes/or_spec.rb +3 -7
- data/spec/chewy/query/nodes/prefix_spec.rb +6 -6
- data/spec/chewy/query/nodes/query_spec.rb +3 -3
- data/spec/chewy/query/nodes/range_spec.rb +19 -19
- data/spec/chewy/query/nodes/raw_spec.rb +2 -2
- data/spec/chewy/query/nodes/regexp_spec.rb +31 -19
- data/spec/chewy/query/nodes/script_spec.rb +5 -5
- data/spec/chewy/query/pagination/kaminari_spec.rb +2 -2
- data/spec/chewy/query/pagination/will_paginage_spec.rb +6 -7
- data/spec/chewy/query/pagination_spec.rb +2 -3
- data/spec/chewy/query_spec.rb +208 -145
- data/spec/chewy/repository_spec.rb +8 -8
- data/spec/chewy/rspec/update_index_spec.rb +180 -111
- data/spec/chewy/search_spec.rb +8 -8
- data/spec/chewy/strategy/active_job_spec.rb +2 -2
- data/spec/chewy/strategy/atomic_spec.rb +4 -1
- data/spec/chewy/strategy/resque_spec.rb +2 -2
- data/spec/chewy/strategy/sidekiq_spec.rb +2 -2
- data/spec/chewy/type/actions_spec.rb +1 -1
- data/spec/chewy/type/adapter/active_record_spec.rb +255 -149
- data/spec/chewy/type/adapter/mongoid_spec.rb +169 -108
- data/spec/chewy/type/adapter/object_spec.rb +56 -40
- data/spec/chewy/type/adapter/sequel_spec.rb +248 -163
- data/spec/chewy/type/import_spec.rb +78 -47
- data/spec/chewy/type/mapping_spec.rb +6 -6
- data/spec/chewy/type/observe_spec.rb +20 -14
- data/spec/chewy/type/witchcraft_spec.rb +89 -43
- data/spec/chewy/type_spec.rb +4 -3
- data/spec/chewy_spec.rb +10 -8
- data/spec/spec_helper.rb +3 -0
- data/spec/support/active_record.rb +1 -1
- data/spec/support/class_helpers.rb +10 -11
- data/spec/support/mongoid.rb +2 -2
- data/spec/support/sequel.rb +1 -1
- metadata +65 -35
- data/gemfiles/rails.4.0.activerecord.kaminari.gemfile +0 -14
- data/gemfiles/rails.4.0.activerecord.will_paginate.gemfile +0 -14
- data/gemfiles/rails.4.0.mongoid.4.0.0.gemfile +0 -15
- data/gemfiles/rails.4.0.mongoid.5.1.0.gemfile +0 -15
- data/gemfiles/rails.4.0.mongoid.5.1.0.kaminari.gemfile +0 -14
- data/gemfiles/rails.4.0.mongoid.5.1.0.will_paginate.gemfile +0 -14
- data/gemfiles/rails.4.1.activerecord.gemfile +0 -15
- data/gemfiles/rails.4.1.activerecord.kaminari.gemfile +0 -14
- data/gemfiles/rails.4.1.activerecord.will_paginate.gemfile +0 -14
- data/gemfiles/rails.4.1.mongoid.4.0.0.gemfile +0 -15
- data/gemfiles/rails.4.1.mongoid.4.0.0.kaminari.gemfile +0 -14
- data/gemfiles/rails.4.1.mongoid.4.0.0.will_paginate.gemfile +0 -14
- data/gemfiles/rails.4.1.mongoid.5.1.0.gemfile +0 -15
- data/gemfiles/rails.4.1.mongoid.5.1.0.kaminari.gemfile +0 -14
- data/gemfiles/rails.4.1.mongoid.5.1.0.will_paginate.gemfile +0 -14
- data/gemfiles/rails.5.0.0.beta3.activerecord.gemfile +0 -16
- data/gemfiles/rails.5.0.0.beta3.activerecord.kaminari.gemfile +0 -16
- data/gemfiles/rails.5.0.0.beta3.activerecord.will_paginate.gemfile +0 -15
@@ -2,17 +2,17 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Exists do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { name? }).to eq(
|
9
|
+
specify { expect(render { name? }).to eq(exists: { field: 'name' }) }
|
10
10
|
|
11
|
-
specify { expect(render { !!name? }).to eq(
|
12
|
-
specify { expect(render { !!name }).to eq(
|
13
|
-
specify { expect(render { name != nil }).to eq(
|
14
|
-
specify { expect(render { !
|
11
|
+
specify { expect(render { !!name? }).to eq(exists: { field: 'name' }) }
|
12
|
+
specify { expect(render { !!name }).to eq(exists: { field: 'name' }) }
|
13
|
+
specify { expect(render { name != nil }).to eq(exists: { field: 'name' }) } # rubocop:disable Style/NonNilCheck
|
14
|
+
specify { expect(render { !name.nil? }).to eq(exists: { field: 'name' }) }
|
15
15
|
|
16
|
-
specify { expect(render { ~name? }).to eq(
|
16
|
+
specify { expect(render { ~name? }).to eq(exists: { field: 'name' }) }
|
17
17
|
end
|
18
18
|
end
|
@@ -2,39 +2,58 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::HasChild do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { has_child('child') }).to eq(
|
9
|
+
specify { expect(render { has_child('child') }).to eq(has_child: { type: 'child' }) }
|
10
10
|
|
11
|
+
specify do
|
12
|
+
expect(render { has_child('child').filter(term: { name: 'name' }) })
|
13
|
+
.to eq(has_child: { type: 'child', filter: { term: { name: 'name' } } })
|
14
|
+
end
|
15
|
+
specify do
|
16
|
+
expect(render { has_child('child').filter { name == 'name' } })
|
17
|
+
.to eq(has_child: { type: 'child', filter: { term: { 'name' => 'name' } } })
|
18
|
+
end
|
19
|
+
specify do
|
20
|
+
expect(render { has_child('child').filter(term: { name: 'name' }).filter { age < 42 } })
|
21
|
+
.to eq(has_child: { type: 'child', filter: { and: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
|
22
|
+
end
|
23
|
+
specify do
|
24
|
+
expect(render { has_child('child').filter(term: { name: 'name' }).filter { age < 42 }.filter_mode(:or) })
|
25
|
+
.to eq(has_child: { type: 'child', filter: { or: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
|
26
|
+
end
|
11
27
|
|
12
|
-
specify
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
specify
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
.to eq({has_child: {type: 'child', query: {bool: {must: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
|
25
|
-
specify { expect(render { has_child('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}).query_mode(:should) })
|
26
|
-
.to eq({has_child: {type: 'child', query: {bool: {should: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
|
28
|
+
specify do
|
29
|
+
expect(render { has_child('child').query(match: { name: 'name' }) })
|
30
|
+
.to eq(has_child: { type: 'child', query: { match: { name: 'name' } } })
|
31
|
+
end
|
32
|
+
specify do
|
33
|
+
expect(render { has_child('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }) })
|
34
|
+
.to eq(has_child: { type: 'child', query: { bool: { must: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
|
35
|
+
end
|
36
|
+
specify do
|
37
|
+
expect(render { has_child('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }).query_mode(:should) })
|
38
|
+
.to eq(has_child: { type: 'child', query: { bool: { should: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
|
39
|
+
end
|
27
40
|
|
28
|
-
specify
|
29
|
-
|
30
|
-
|
31
|
-
|
41
|
+
specify do
|
42
|
+
expect(render { has_child('child').filter { name == 'name' }.query(match: { name: 'name' }) })
|
43
|
+
.to eq(has_child: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { term: { 'name' => 'name' } } } } })
|
44
|
+
end
|
45
|
+
specify do
|
46
|
+
expect(render { has_child('child').filter { name == 'name' }.query(match: { name: 'name' }).filter { age < 42 } })
|
47
|
+
.to eq(has_child: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { and: [{ term: { 'name' => 'name' } }, range: { 'age' => { lt: 42 } }] } } } })
|
48
|
+
end
|
32
49
|
|
33
50
|
context do
|
34
51
|
let(:name) { 'Name' }
|
35
52
|
|
36
|
-
specify
|
37
|
-
|
53
|
+
specify do
|
54
|
+
expect(render { has_child('child').filter { name == o { name } } })
|
55
|
+
.to eq(has_child: { type: 'child', filter: { term: { 'name' => 'Name' } } })
|
56
|
+
end
|
38
57
|
end
|
39
58
|
end
|
40
59
|
end
|
@@ -2,39 +2,58 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::HasParent do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { has_parent('child') }).to eq(
|
9
|
+
specify { expect(render { has_parent('child') }).to eq(has_parent: { type: 'child' }) }
|
10
10
|
|
11
|
+
specify do
|
12
|
+
expect(render { has_parent('child').filter(term: { name: 'name' }) })
|
13
|
+
.to eq(has_parent: { type: 'child', filter: { term: { name: 'name' } } })
|
14
|
+
end
|
15
|
+
specify do
|
16
|
+
expect(render { has_parent('child').filter { name == 'name' } })
|
17
|
+
.to eq(has_parent: { type: 'child', filter: { term: { 'name' => 'name' } } })
|
18
|
+
end
|
19
|
+
specify do
|
20
|
+
expect(render { has_parent('child').filter(term: { name: 'name' }).filter { age < 42 } })
|
21
|
+
.to eq(has_parent: { type: 'child', filter: { and: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
|
22
|
+
end
|
23
|
+
specify do
|
24
|
+
expect(render { has_parent('child').filter(term: { name: 'name' }).filter { age < 42 }.filter_mode(:or) })
|
25
|
+
.to eq(has_parent: { type: 'child', filter: { or: [{ term: { name: 'name' } }, range: { 'age' => { lt: 42 } }] } })
|
26
|
+
end
|
11
27
|
|
12
|
-
specify
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
specify
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
.to eq({has_parent: {type: 'child', query: {bool: {must: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
|
25
|
-
specify { expect(render { has_parent('child').query(match: {name: 'name'}).query(match: {surname: 'surname'}).query_mode(:should) })
|
26
|
-
.to eq({has_parent: {type: 'child', query: {bool: {should: [{match: {name: 'name'}}, {match: {surname: 'surname'}}]}}}}) }
|
28
|
+
specify do
|
29
|
+
expect(render { has_parent('child').query(match: { name: 'name' }) })
|
30
|
+
.to eq(has_parent: { type: 'child', query: { match: { name: 'name' } } })
|
31
|
+
end
|
32
|
+
specify do
|
33
|
+
expect(render { has_parent('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }) })
|
34
|
+
.to eq(has_parent: { type: 'child', query: { bool: { must: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
|
35
|
+
end
|
36
|
+
specify do
|
37
|
+
expect(render { has_parent('child').query(match: { name: 'name' }).query(match: { surname: 'surname' }).query_mode(:should) })
|
38
|
+
.to eq(has_parent: { type: 'child', query: { bool: { should: [{ match: { name: 'name' } }, { match: { surname: 'surname' } }] } } })
|
39
|
+
end
|
27
40
|
|
28
|
-
specify
|
29
|
-
|
30
|
-
|
31
|
-
|
41
|
+
specify do
|
42
|
+
expect(render { has_parent('child').filter { name == 'name' }.query(match: { name: 'name' }) })
|
43
|
+
.to eq(has_parent: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { term: { 'name' => 'name' } } } } })
|
44
|
+
end
|
45
|
+
specify do
|
46
|
+
expect(render { has_parent('child').filter { name == 'name' }.query(match: { name: 'name' }).filter { age < 42 } })
|
47
|
+
.to eq(has_parent: { type: 'child', query: { filtered: { query: { match: { name: 'name' } }, filter: { and: [{ term: { 'name' => 'name' } }, range: { 'age' => { lt: 42 } }] } } } })
|
48
|
+
end
|
32
49
|
|
33
50
|
context do
|
34
51
|
let(:name) { 'Name' }
|
35
52
|
|
36
|
-
specify
|
37
|
-
|
53
|
+
specify do
|
54
|
+
expect(render { has_parent('child').filter { name == o { name } } })
|
55
|
+
.to eq(has_parent: { type: 'child', filter: { term: { 'name' => 'Name' } } })
|
56
|
+
end
|
38
57
|
end
|
39
58
|
end
|
40
59
|
end
|
@@ -2,10 +2,10 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::MatchAll do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { match_all }).to eq(
|
9
|
+
specify { expect(render { match_all }).to eq(match_all: {}) }
|
10
10
|
end
|
11
11
|
end
|
@@ -2,14 +2,15 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Missing do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { !name }).to eq(
|
10
|
-
specify { expect(render { !name? }).to eq(
|
11
|
-
specify { expect(render { name == nil }).to eq(
|
9
|
+
specify { expect(render { !name }).to eq(missing: { field: 'name', existence: true, null_value: false }) }
|
10
|
+
specify { expect(render { !name? }).to eq(missing: { field: 'name', existence: true, null_value: true }) }
|
11
|
+
specify { expect(render { name == nil }).to eq(missing: { field: 'name', existence: false, null_value: true }) } # rubocop:disable Style/NilComparison
|
12
|
+
specify { expect(render { name.nil? }).to eq(missing: { field: 'name', existence: false, null_value: true }) }
|
12
13
|
|
13
|
-
specify { expect(render { ~!name }).to eq(
|
14
|
+
specify { expect(render { ~!name }).to eq(missing: { field: 'name', existence: true, null_value: false }) }
|
14
15
|
end
|
15
16
|
end
|
@@ -2,15 +2,11 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Not do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { !(email == 'email') }).to eq({
|
10
|
-
|
11
|
-
}) }
|
12
|
-
specify { expect(render { ~!(email == 'email') }).to eq({
|
13
|
-
not: {filter: {term: {'email' => 'email'}}, _cache: true}
|
14
|
-
}) }
|
9
|
+
specify { expect(render { !(email == 'email') }).to eq(not: { term: { 'email' => 'email' } }) }
|
10
|
+
specify { expect(render { ~!(email == 'email') }).to eq(not: { filter: { term: { 'email' => 'email' } }, _cache: true }) }
|
15
11
|
end
|
16
12
|
end
|
@@ -2,15 +2,11 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Or do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { name? | (email == 'email') }).to eq({
|
10
|
-
|
11
|
-
}) }
|
12
|
-
specify { expect(render { ~(name? | (email == 'email')) }).to eq({
|
13
|
-
or: {filters: [{exists: {field: 'name'}}, {term: {'email' => 'email'}}], _cache: true}
|
14
|
-
}) }
|
9
|
+
specify { expect(render { name? | (email == 'email') }).to eq(or: [{ exists: { field: 'name' } }, { term: { 'email' => 'email' } }]) }
|
10
|
+
specify { expect(render { ~(name? | (email == 'email')) }).to eq(or: { filters: [{ exists: { field: 'name' } }, { term: { 'email' => 'email' } }], _cache: true }) }
|
15
11
|
end
|
16
12
|
end
|
@@ -2,15 +2,15 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Prefix do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { name =~ 'nam' }).to eq(
|
10
|
-
specify { expect(render { name !~ 'nam' }).to eq(
|
9
|
+
specify { expect(render { name =~ 'nam' }).to eq(prefix: { 'name' => 'nam' }) }
|
10
|
+
specify { expect(render { name !~ 'nam' }).to eq(not: { prefix: { 'name' => 'nam' } }) }
|
11
11
|
|
12
|
-
specify { expect(render { ~name =~ 'nam' }).to eq(
|
13
|
-
specify { expect(render { ~name !~ 'nam' }).to eq(
|
14
|
-
specify { expect(render { name(cache: false) =~ 'nam' }).to eq(
|
12
|
+
specify { expect(render { ~name =~ 'nam' }).to eq(prefix: { 'name' => 'nam', _cache: true }) }
|
13
|
+
specify { expect(render { ~name !~ 'nam' }).to eq(not: { prefix: { 'name' => 'nam', _cache: true } }) }
|
14
|
+
specify { expect(render { name(cache: false) =~ 'nam' }).to eq(prefix: { 'name' => 'nam', _cache: false }) }
|
15
15
|
end
|
16
16
|
end
|
@@ -2,11 +2,11 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Query do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { q(query_string: {query: 'name: hello'}) }).to eq(
|
10
|
-
specify { expect(render { ~q(query_string: {query: 'name: hello'}) }).to eq(
|
9
|
+
specify { expect(render { q(query_string: { query: 'name: hello' }) }).to eq(query: { query_string: { query: 'name: hello' } }) }
|
10
|
+
specify { expect(render { ~q(query_string: { query: 'name: hello' }) }).to eq(fquery: { query: { query_string: { query: 'name: hello' } }, _cache: true }) }
|
11
11
|
end
|
12
12
|
end
|
@@ -2,31 +2,31 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Range do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { age > nil }).to eq(
|
10
|
-
specify { expect(render { age == (nil..nil) }).to eq(
|
9
|
+
specify { expect(render { age > nil }).to eq(range: { 'age' => { gt: nil } }) }
|
10
|
+
specify { expect(render { age == (nil..nil) }).to eq(range: { 'age' => { gt: nil, lt: nil } }) }
|
11
11
|
|
12
|
-
specify { expect(render { age > 42 }).to eq(
|
13
|
-
specify { expect(render { age == (42..45) }).to eq(
|
14
|
-
specify { expect(render { age == [42..45] }).to eq(
|
15
|
-
specify { expect(render { (age > 42) & (age <= 45) }).to eq(
|
12
|
+
specify { expect(render { age > 42 }).to eq(range: { 'age' => { gt: 42 } }) }
|
13
|
+
specify { expect(render { age == (42..45) }).to eq(range: { 'age' => { gt: 42, lt: 45 } }) }
|
14
|
+
specify { expect(render { age == [42..45] }).to eq(range: { 'age' => { gte: 42, lte: 45 } }) }
|
15
|
+
specify { expect(render { (age > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 } }) }
|
16
16
|
|
17
|
-
specify { expect(render { ~age > 42 }).to eq(
|
18
|
-
specify { expect(render { ~age == (42..45) }).to eq(
|
19
|
-
specify { expect(render { ~age == [42..45] }).to eq(
|
20
|
-
specify { expect(render { (age > 42) & ~(age <= 45) }).to eq(
|
21
|
-
specify { expect(render { (~age > 42) & (age <= 45) }).to eq(
|
17
|
+
specify { expect(render { ~age > 42 }).to eq(range: { 'age' => { gt: 42 }, _cache: true }) }
|
18
|
+
specify { expect(render { ~age == (42..45) }).to eq(range: { 'age' => { gt: 42, lt: 45 }, _cache: true }) }
|
19
|
+
specify { expect(render { ~age == [42..45] }).to eq(range: { 'age' => { gte: 42, lte: 45 }, _cache: true }) }
|
20
|
+
specify { expect(render { (age > 42) & ~(age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, _cache: true }) }
|
21
|
+
specify { expect(render { (~age > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, _cache: true }) }
|
22
22
|
|
23
|
-
specify { expect(render { age(:i) > 42 }).to eq(
|
24
|
-
specify { expect(render { age(:index) > 42 }).to eq(
|
25
|
-
specify { expect(render { age(:f) > 42 }).to eq(
|
26
|
-
specify { expect(render { age(:fielddata) > 42 }).to eq(
|
27
|
-
specify { expect(render { (age(:f) > 42) & (age <= 45) }).to eq(
|
23
|
+
specify { expect(render { age(:i) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :index }) }
|
24
|
+
specify { expect(render { age(:index) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :index }) }
|
25
|
+
specify { expect(render { age(:f) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata }) }
|
26
|
+
specify { expect(render { age(:fielddata) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata }) }
|
27
|
+
specify { expect(render { (age(:f) > 42) & (age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, execution: :fielddata }) }
|
28
28
|
|
29
|
-
specify { expect(render { ~age(:f) > 42 }).to eq(
|
30
|
-
specify { expect(render { (age(:f) > 42) & (~age <= 45) }).to eq(
|
29
|
+
specify { expect(render { ~age(:f) > 42 }).to eq(range: { 'age' => { gt: 42 }, execution: :fielddata, _cache: true }) }
|
30
|
+
specify { expect(render { (age(:f) > 42) & (~age <= 45) }).to eq(range: { 'age' => { gt: 42, lte: 45 }, execution: :fielddata, _cache: true }) }
|
31
31
|
end
|
32
32
|
end
|
@@ -2,10 +2,10 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Raw do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { r(term: {name: 'name'}) }).to eq(
|
9
|
+
specify { expect(render { r(term: { name: 'name' }) }).to eq(term: { name: 'name' }) }
|
10
10
|
end
|
11
11
|
end
|
@@ -2,30 +2,42 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Regexp do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { names.first == /nam.*/ }).to eq(
|
10
|
-
specify { expect(render { names.first =~ /nam.*/ }).to eq(
|
11
|
-
specify { expect(render { name != /nam.*/ }).to eq(
|
12
|
-
specify { expect(render { name !~ /nam.*/ }).to eq(
|
9
|
+
specify { expect(render { names.first == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*' }) }
|
10
|
+
specify { expect(render { names.first =~ /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*' }) }
|
11
|
+
specify { expect(render { name != /nam.*/ }).to eq(not: { regexp: { 'name' => 'nam.*' } }) }
|
12
|
+
specify { expect(render { name !~ /nam.*/ }).to eq(not: { regexp: { 'name' => 'nam.*' } }) }
|
13
13
|
|
14
|
-
specify
|
15
|
-
|
16
|
-
|
17
|
-
|
14
|
+
specify do
|
15
|
+
expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) == /nam.*/ })
|
16
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
|
17
|
+
end
|
18
|
+
specify do
|
19
|
+
expect(render { names.first(:anystring, :intersection, :borogoves) == /nam.*/ })
|
20
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
|
21
|
+
end
|
18
22
|
|
19
|
-
specify
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
+
specify do
|
24
|
+
expect(render { names.first(flags: [:anystring, :intersection, :borogoves]) =~ /nam.*/ })
|
25
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
|
26
|
+
end
|
27
|
+
specify do
|
28
|
+
expect(render { names.first(:anystring, :intersection, :borogoves) =~ /nam.*/ })
|
29
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING|INTERSECTION' } })
|
30
|
+
end
|
23
31
|
|
24
|
-
specify { expect(render { ~names.first == /nam.*/ }).to eq(
|
25
|
-
specify { expect(render { names.first(cache: 'name') == /nam.*/ }).to eq(
|
26
|
-
specify
|
27
|
-
|
28
|
-
|
29
|
-
|
32
|
+
specify { expect(render { ~names.first == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*', _cache: true, _cache_key: 'nam.*' }) }
|
33
|
+
specify { expect(render { names.first(cache: 'name') == /nam.*/ }).to eq(regexp: { 'names.first' => 'nam.*', _cache: true, _cache_key: 'name' }) }
|
34
|
+
specify do
|
35
|
+
expect(render { ~names.first(:anystring) =~ /nam.*/ })
|
36
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING' }, _cache: true, _cache_key: 'nam.*' })
|
37
|
+
end
|
38
|
+
specify do
|
39
|
+
expect(render { names.first(:anystring, cache: 'name') =~ /nam.*/ })
|
40
|
+
.to eq(regexp: { 'names.first' => { value: 'nam.*', flags: 'ANYSTRING' }, _cache: true, _cache_key: 'name' })
|
41
|
+
end
|
30
42
|
end
|
31
43
|
end
|
@@ -2,14 +2,14 @@ require 'spec_helper'
|
|
2
2
|
|
3
3
|
describe Chewy::Query::Nodes::Script do
|
4
4
|
describe '#__render__' do
|
5
|
-
def render
|
5
|
+
def render(&block)
|
6
6
|
Chewy::Query::Filters.new(&block).__render__
|
7
7
|
end
|
8
8
|
|
9
|
-
specify { expect(render { s('var = val') }).to eq(
|
10
|
-
specify { expect(render { s('var = val', val: 42) }).to eq(
|
9
|
+
specify { expect(render { s('var = val') }).to eq(script: { script: 'var = val' }) }
|
10
|
+
specify { expect(render { s('var = val', val: 42) }).to eq(script: { script: 'var = val', params: { val: 42 } }) }
|
11
11
|
|
12
|
-
specify { expect(render { ~s('var = val') }).to eq(
|
13
|
-
specify { expect(render { ~s('var = val', val: 42) }).to eq(
|
12
|
+
specify { expect(render { ~s('var = val') }).to eq(script: { script: 'var = val', _cache: true }) }
|
13
|
+
specify { expect(render { ~s('var = val', val: 42) }).to eq(script: { script: 'var = val', params: { val: 42 }, _cache: true }) }
|
14
14
|
end
|
15
15
|
end
|