axiom-arango-adapter 0.0.1
Sign up to get free protection for your applications and to get access to all the features.
- data/.gitignore +4 -0
- data/.rspec +5 -0
- data/.travis.yml +25 -0
- data/Gemfile +9 -0
- data/Gemfile.devtools +57 -0
- data/Guardfile +18 -0
- data/LICENSE +20 -0
- data/README.md +92 -0
- data/Rakefile +2 -0
- data/TODO +1 -0
- data/axiom-arango-adapter.gemspec +26 -0
- data/config/flay.yml +3 -0
- data/config/flog.yml +2 -0
- data/config/mutant.yml +3 -0
- data/config/roodi.yml +18 -0
- data/config/site.reek +102 -0
- data/config/yardstick.yml +2 -0
- data/lib/axiom-arango-adapter.rb +2 -0
- data/lib/axiom/adapter/arango.rb +40 -0
- data/lib/axiom/adapter/arango/adapter.rb +68 -0
- data/lib/axiom/adapter/arango/gateway.rb +356 -0
- data/lib/axiom/adapter/arango/reader.rb +98 -0
- data/lib/axiom/adapter/arango/visitor.rb +100 -0
- data/lib/axiom/adapter/arango/visitor/aggregate.rb +132 -0
- data/lib/axiom/adapter/arango/visitor/attribute.rb +26 -0
- data/lib/axiom/adapter/arango/visitor/binary.rb +77 -0
- data/lib/axiom/adapter/arango/visitor/for.rb +75 -0
- data/lib/axiom/adapter/arango/visitor/for/base.rb +40 -0
- data/lib/axiom/adapter/arango/visitor/for/binary.rb +108 -0
- data/lib/axiom/adapter/arango/visitor/for/binary/join.rb +131 -0
- data/lib/axiom/adapter/arango/visitor/for/binary/product.rb +48 -0
- data/lib/axiom/adapter/arango/visitor/for/summarization.rb +113 -0
- data/lib/axiom/adapter/arango/visitor/for/unary.rb +29 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/extension.rb +72 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/limit.rb +31 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/offset.rb +34 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/order.rb +63 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/projection.rb +32 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/rename.rb +88 -0
- data/lib/axiom/adapter/arango/visitor/for/unary/restriction.rb +42 -0
- data/lib/axiom/adapter/arango/visitor/function.rb +33 -0
- data/lib/axiom/adapter/arango/visitor/header.rb +55 -0
- data/lib/axiom/adapter/arango/visitor/literal.rb +26 -0
- data/lib/axiom/adapter/arango/visitor/reverse.rb +27 -0
- data/spec/fuzzer.rb +53 -0
- data/spec/integration/arango/read_spec.rb +166 -0
- data/spec/setup/arangodb.sh +61 -0
- data/spec/setup/run.sh +23 -0
- data/spec/shared/aql_behavior.rb +7 -0
- data/spec/shared/binary_relation_method_behaviour.rb +53 -0
- data/spec/shared/unary_relation_method_behaviour.rb +21 -0
- data/spec/spec_helper.rb +51 -0
- data/spec/support/ice_nine_config.rb +6 -0
- data/spec/unit/axiom/adapter/arango/adapter/class_methods/new_spec.rb +24 -0
- data/spec/unit/axiom/adapter/arango/adapter/gateway_spec.rb +11 -0
- data/spec/unit/axiom/adapter/arango/adapter/reader_spec.rb +12 -0
- data/spec/unit/axiom/adapter/arango/gateway/class_methods/new_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/gateway/difference_spec.rb +16 -0
- data/spec/unit/axiom/adapter/arango/gateway/drop_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/each_spec.rb +78 -0
- data/spec/unit/axiom/adapter/arango/gateway/extend_spec.rb +26 -0
- data/spec/unit/axiom/adapter/arango/gateway/intersect_spec.rb +16 -0
- data/spec/unit/axiom/adapter/arango/gateway/join_spec.rb +43 -0
- data/spec/unit/axiom/adapter/arango/gateway/materialize_spec.rb +26 -0
- data/spec/unit/axiom/adapter/arango/gateway/optimize_spec.rb +22 -0
- data/spec/unit/axiom/adapter/arango/gateway/product_spec.rb +16 -0
- data/spec/unit/axiom/adapter/arango/gateway/project_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/remove_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/rename_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/respond_to_predicate_spec.rb +28 -0
- data/spec/unit/axiom/adapter/arango/gateway/restrict_spec.rb +26 -0
- data/spec/unit/axiom/adapter/arango/gateway/reverse_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/sort_by_spec.rb +26 -0
- data/spec/unit/axiom/adapter/arango/gateway/summarize_spec.rb +150 -0
- data/spec/unit/axiom/adapter/arango/gateway/take_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/gateway/unhandled_message_spec.rb +17 -0
- data/spec/unit/axiom/adapter/arango/gateway/union_spec.rb +16 -0
- data/spec/unit/axiom/adapter/arango/reader/each_spec.rb +43 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/count/root_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/count_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/maximum/root_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/maximum_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/minimum/root_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/minimum_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/sum/root_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/aggregate/sum_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/attribute/root_spec.rb +12 -0
- data/spec/unit/axiom/adapter/arango/visitor/binary/root_spec.rb +15 -0
- data/spec/unit/axiom/adapter/arango/visitor/class_methods/build_spec.rb +37 -0
- data/spec/unit/axiom/adapter/arango/visitor/class_methods/run_spec.rb +26 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/base/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/join/local_name_spec.rb +20 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/join/right/root_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/join/root_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/join_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/local_name_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/product/right/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/product/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/product_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/right/join_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/right/local_name_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/binary/right/product_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/local_name_spec.rb +21 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/root_spec.rb +29 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/summarization/root_spec.rb +53 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/extension/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/extension_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/limit/root_spec.rb +17 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/limit_spec.rb +17 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/offset/root_spec.rb +17 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/offset_spec.rb +17 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/order/root_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/order_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/projection/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/projection_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/rename/root_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/rename_spec.rb +13 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/restriction/root_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/for/unary/restriction_spec.rb +14 -0
- data/spec/unit/axiom/adapter/arango/visitor/header/root_spec.rb +12 -0
- data/spec/unit/axiom/adapter/arango/visitor/literal/root_spec.rb +10 -0
- data/spec/unit/axiom/adapter/arango/visitor/static/root_spec.rb +19 -0
- data/spec/unit/axiom/adapter/arango/visitor/visit_spec.rb +52 -0
- data/spec/unit/axiom/adapter/arango/visitor/visitor_spec.rb +39 -0
- metadata +379 -0
@@ -0,0 +1,26 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor, '.run' do
|
4
|
+
let(:object) { described_class }
|
5
|
+
|
6
|
+
let(:relation) { mock('Axiom Node') }
|
7
|
+
let(:aql_node) { mock('AQL Node') }
|
8
|
+
let(:visitor) { mock('Visitor', :root => aql_node) }
|
9
|
+
|
10
|
+
class Dummy
|
11
|
+
end
|
12
|
+
|
13
|
+
let!(:test_visitor) do
|
14
|
+
aql_node = self.aql_node
|
15
|
+
Class.new(described_class) do
|
16
|
+
handle(Dummy)
|
17
|
+
define_method :root do
|
18
|
+
aql_node
|
19
|
+
end
|
20
|
+
end
|
21
|
+
end
|
22
|
+
|
23
|
+
subject { object.run(Dummy.new) }
|
24
|
+
|
25
|
+
it { should be(aql_node) }
|
26
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Base, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base }
|
7
|
+
let(:object) { described_class.new(relation, context) }
|
8
|
+
|
9
|
+
expect_aql <<-AQL
|
10
|
+
FOR `base` IN `name`
|
11
|
+
RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`}
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,20 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Join, '#local_name' do
|
4
|
+
let(:object) { described_class.new(node, context) }
|
5
|
+
let(:node) { mock('Node') }
|
6
|
+
subject { object.local_name }
|
7
|
+
|
8
|
+
|
9
|
+
context 'as root' do
|
10
|
+
let(:context) { nil }
|
11
|
+
it { should eql(AQL.name_node(:local_0)) }
|
12
|
+
it_should_behave_like 'an idempotent method'
|
13
|
+
end
|
14
|
+
|
15
|
+
context 'as non root' do
|
16
|
+
let(:context) { mock('Context', :depth => 0) }
|
17
|
+
it { should eql(AQL.name_node(:local_1)) }
|
18
|
+
it_should_behave_like 'an idempotent method'
|
19
|
+
end
|
20
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Join, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.join(base_c) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `local_0` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_c` RETURN {"baz": `base`.`baz`, "bar": `base`.`bar`})
|
11
|
+
FILTER (`local_0`.`bar` == `right`.`bar`)
|
12
|
+
RETURN {"foo": `local_0`.`foo`, "bar": `local_0`.`bar`, "baz": `right`.`baz`}
|
13
|
+
AQL
|
14
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Join, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.join(base_c) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `local_0` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_c` RETURN {"baz": `base`.`baz`, "bar": `base`.`bar`})
|
11
|
+
FILTER (`local_0`.`bar` == `right`.`bar`)
|
12
|
+
RETURN {"foo": `local_0`.`foo`, "bar": `local_0`.`bar`, "baz": `right`.`baz`}
|
13
|
+
AQL
|
14
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Join, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.join(base_c) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `local_0` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_c` RETURN {"baz": `base`.`baz`, "bar": `base`.`bar`})
|
11
|
+
FILTER (`local_0`.`bar` == `right`.`bar`)
|
12
|
+
RETURN {"foo": `local_0`.`foo`, "bar": `local_0`.`bar`, "baz": `right`.`baz`}
|
13
|
+
AQL
|
14
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary, '#local_name' do
|
4
|
+
subject { object.local_name }
|
5
|
+
|
6
|
+
let(:object) { described_class.new(relation, context) }
|
7
|
+
|
8
|
+
let(:relation) { mock('Relation') }
|
9
|
+
let(:context) { mock('Context') }
|
10
|
+
|
11
|
+
it { should eql(AQL.name_node('left')) }
|
12
|
+
|
13
|
+
it_should_behave_like 'an idempotent method'
|
14
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Product, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.product(base_b) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `left` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_b` RETURN {"baz": `base`.`baz`})
|
11
|
+
RETURN {"foo": `left`.`foo`, "bar": `left`.`bar`, "baz": `right`.`baz`}
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Product, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.product(base_b) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `left` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_b` RETURN {"baz": `base`.`baz`})
|
11
|
+
RETURN {"foo": `left`.`foo`, "bar": `left`.`bar`, "baz": `right`.`baz`}
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Product, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.product(base_b) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `left` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_b` RETURN {"baz": `base`.`baz`})
|
11
|
+
RETURN {"foo": `left`.`foo`, "bar": `left`.`bar`, "baz": `right`.`baz`}
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Join, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.join(base_c) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `local_0` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_c` RETURN {"baz": `base`.`baz`, "bar": `base`.`bar`})
|
11
|
+
FILTER (`local_0`.`bar` == `right`.`bar`)
|
12
|
+
RETURN {"foo": `local_0`.`foo`, "bar": `local_0`.`bar`, "baz": `right`.`baz`}
|
13
|
+
AQL
|
14
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Right, '#local_name' do
|
4
|
+
subject { object.local_name }
|
5
|
+
|
6
|
+
let(:object) { described_class.new(relation, context) }
|
7
|
+
let(:relation) { mock('Relation') }
|
8
|
+
let(:context) { mock('Context') }
|
9
|
+
|
10
|
+
it { should eql(AQL.name_node('right')) }
|
11
|
+
|
12
|
+
it_should_behave_like 'an idempotent method'
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Binary::Product, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.product(base_b) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `left` IN (FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
10
|
+
FOR `right` IN (FOR `base` IN `name_b` RETURN {"baz": `base`.`baz`})
|
11
|
+
RETURN {"foo": `left`.`foo`, "bar": `left`.`bar`, "baz": `right`.`baz`}
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For, '#local_name' do
|
4
|
+
subject { object.local_name }
|
5
|
+
let(:object) { class_under_test.new(relation, context) }
|
6
|
+
let(:relation) { mock('Relation') }
|
7
|
+
let(:context) { mock('Context') }
|
8
|
+
|
9
|
+
let(:local_name) { mock('Local Name') }
|
10
|
+
|
11
|
+
let(:class_under_test) do
|
12
|
+
local_name = self.local_name
|
13
|
+
Class.new(described_class) do
|
14
|
+
const_set('LOCAL_NAME', local_name)
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
it_should_behave_like 'an idempotent method'
|
19
|
+
|
20
|
+
it { should be(local_name) }
|
21
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For, '#root' do
|
4
|
+
subject { object.root.aql }
|
5
|
+
|
6
|
+
let(:object) { class_under_test.new(relation, context) }
|
7
|
+
|
8
|
+
let(:context) { mock('Context') }
|
9
|
+
|
10
|
+
let(:class_under_test) do
|
11
|
+
local = self.local
|
12
|
+
Class.new(described_class) do
|
13
|
+
define_method :local_name do
|
14
|
+
local
|
15
|
+
end
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
let(:header) { Axiom::Relation::Header.coerce([[:id, Integer]]) }
|
20
|
+
let(:operand) { Axiom::Relation::Base.new(:name_a, header) }
|
21
|
+
let(:relation) { operand.restrict { |r| r.id.eq(1) } }
|
22
|
+
let(:local) { AQL.name_node('local') }
|
23
|
+
let(:source) { Axiom::Adapter::Arango::Visitor.run(operand) }
|
24
|
+
let(:body) { AQL.name_node('foo') }
|
25
|
+
|
26
|
+
it { should eql('FOR `local` IN (FOR `base` IN `name_a` RETURN {"id": `base`.`id`}) RETURN {"id": `local`.`id`}') }
|
27
|
+
|
28
|
+
it_should_behave_like 'an idempotent method'
|
29
|
+
end
|
@@ -0,0 +1,53 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Summarization, '#root' do
|
4
|
+
|
5
|
+
let(:object) { described_class.new(relation, context) }
|
6
|
+
let(:context) { mock('Context') }
|
7
|
+
|
8
|
+
subject { object.root }
|
9
|
+
|
10
|
+
context 'max' do
|
11
|
+
let(:relation) { base.summarize([:foo]) { |r| r.add(:count, r.bar.max) } }
|
12
|
+
|
13
|
+
expect_aql <<-AQL
|
14
|
+
FOR `summarization` IN
|
15
|
+
(FOR `base` IN `name` RETURN {\"foo\": `base`.`foo`, \"bar\": `base`.`bar`})
|
16
|
+
COLLECT `foo` = `summarization`.`foo` INTO `collect`
|
17
|
+
RETURN {"foo": `foo`, "count": MAX((FOR `aggregate` IN `collect` FILTER (`aggregate`.`summarization`.`bar` != null) RETURN `aggregate`.`summarization`.`bar`))}
|
18
|
+
AQL
|
19
|
+
end
|
20
|
+
|
21
|
+
context 'min' do
|
22
|
+
let(:relation) { base.summarize([:foo]) { |r| r.add(:count, r.bar.min) } }
|
23
|
+
|
24
|
+
expect_aql <<-AQL
|
25
|
+
FOR `summarization` IN
|
26
|
+
(FOR `base` IN `name` RETURN {\"foo\": `base`.`foo`, \"bar\": `base`.`bar`})
|
27
|
+
COLLECT `foo` = `summarization`.`foo` INTO `collect`
|
28
|
+
RETURN {"foo": `foo`, "count": MIN((FOR `aggregate` IN `collect` FILTER (`aggregate`.`summarization`.`bar` != null) RETURN `aggregate`.`summarization`.`bar`))}
|
29
|
+
AQL
|
30
|
+
end
|
31
|
+
|
32
|
+
context 'sum' do
|
33
|
+
let(:relation) { base.summarize([:foo]) { |r| r.add(:count, r.bar.sum) } }
|
34
|
+
|
35
|
+
expect_aql <<-AQL
|
36
|
+
FOR `summarization` IN
|
37
|
+
(FOR `base` IN `name` RETURN {\"foo\": `base`.`foo`, \"bar\": `base`.`bar`})
|
38
|
+
COLLECT `foo` = `summarization`.`foo` INTO `collect`
|
39
|
+
RETURN {"foo": `foo`, "count": SUM((FOR `aggregate` IN `collect` FILTER (`aggregate`.`summarization`.`bar` != null) RETURN `aggregate`.`summarization`.`bar`))}
|
40
|
+
AQL
|
41
|
+
end
|
42
|
+
|
43
|
+
context 'count' do
|
44
|
+
let(:relation) { base.summarize([:bar]) { |r| r.add(:count, r.foo.count) } }
|
45
|
+
|
46
|
+
expect_aql <<-AQL
|
47
|
+
FOR `summarization` IN
|
48
|
+
(FOR `base` IN `name` RETURN {\"foo\": `base`.`foo`, \"bar\": `base`.`bar`})
|
49
|
+
COLLECT `bar` = `summarization`.`bar` INTO `collect`
|
50
|
+
RETURN {"bar": `bar`, "count": LENGTH((FOR `aggregate` IN `collect` FILTER (`aggregate`.`summarization`.`foo` != null) RETURN `aggregate`.`summarization`.`foo`))}
|
51
|
+
AQL
|
52
|
+
end
|
53
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Extension, '#root' do
|
4
|
+
let(:relation) { base.extend { |r| r.add(:baz, r.bar * 2) } }
|
5
|
+
|
6
|
+
subject { object.root }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `extension` IN
|
10
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
11
|
+
RETURN MERGE(`extension`, {"baz": (`extension`.`bar` * 2)})
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,13 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Extension, '#root' do
|
4
|
+
let(:relation) { base.extend { |r| r.add(:baz, r.bar * 2) } }
|
5
|
+
|
6
|
+
subject { object.root }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `extension` IN
|
10
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
11
|
+
RETURN MERGE(`extension`, {"baz": (`extension`.`bar` * 2)})
|
12
|
+
AQL
|
13
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Limit, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] }.take(5) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `limit` IN
|
10
|
+
(FOR `order` IN
|
11
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
12
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
13
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`})
|
14
|
+
LIMIT 0, 5
|
15
|
+
RETURN {"foo": `limit`.`foo`, "bar": `limit`.`bar`}
|
16
|
+
AQL
|
17
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Limit, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] }.take(5) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `limit` IN
|
10
|
+
(FOR `order` IN
|
11
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
12
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
13
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`})
|
14
|
+
LIMIT 0, 5
|
15
|
+
RETURN {"foo": `limit`.`foo`, "bar": `limit`.`bar`}
|
16
|
+
AQL
|
17
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Offset, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] }.drop(5) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `offset` IN
|
10
|
+
(FOR `order` IN
|
11
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
12
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
13
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`})
|
14
|
+
LIMIT 5, 2147483647
|
15
|
+
RETURN {"foo": `offset`.`foo`, "bar": `offset`.`bar`}
|
16
|
+
AQL
|
17
|
+
end
|
@@ -0,0 +1,17 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Offset, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] }.drop(5) }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `offset` IN
|
10
|
+
(FOR `order` IN
|
11
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
12
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
13
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`})
|
14
|
+
LIMIT 5, 2147483647
|
15
|
+
RETURN {"foo": `offset`.`foo`, "bar": `offset`.`bar`}
|
16
|
+
AQL
|
17
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Order, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] } }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `order` IN
|
10
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
11
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
12
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`}
|
13
|
+
AQL
|
14
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require 'spec_helper'
|
2
|
+
|
3
|
+
describe Axiom::Adapter::Arango::Visitor::For::Unary::Order, '#root' do
|
4
|
+
subject { object.root }
|
5
|
+
|
6
|
+
let(:relation) { base.sort_by { |r| [r.foo.asc, r.bar.asc] } }
|
7
|
+
|
8
|
+
expect_aql <<-AQL
|
9
|
+
FOR `order` IN
|
10
|
+
(FOR `base` IN `name` RETURN {"foo": `base`.`foo`, "bar": `base`.`bar`})
|
11
|
+
SORT `order`.`foo` ASC, `order`.`bar` ASC
|
12
|
+
RETURN {"foo": `order`.`foo`, "bar": `order`.`bar`}
|
13
|
+
AQL
|
14
|
+
end
|