summaryrefslogtreecommitdiff
path: root/ext/librethinkdbxx/test/upstream/mutation/update.yaml
diff options
context:
space:
mode:
Diffstat (limited to 'ext/librethinkdbxx/test/upstream/mutation/update.yaml')
-rw-r--r--ext/librethinkdbxx/test/upstream/mutation/update.yaml170
1 files changed, 0 insertions, 170 deletions
diff --git a/ext/librethinkdbxx/test/upstream/mutation/update.yaml b/ext/librethinkdbxx/test/upstream/mutation/update.yaml
deleted file mode 100644
index 3cde0f34..00000000
--- a/ext/librethinkdbxx/test/upstream/mutation/update.yaml
+++ /dev/null
@@ -1,170 +0,0 @@
-desc: Tests updates of selections
-table_variable_name: tbl, tbl2
-tests:
-
- # Set up some data
- - py: tbl.insert([{'id':i} for i in xrange(100)])
- js: |
- tbl.insert(function(){
- var res = []
- for (var i = 0; i < 100; i++) {
- res.push({id:i});
- }
- return res;
- }())
- rb: tbl.insert((0...100).map{ |i| { :id => i } })
- ot: ({'deleted':0.0,'replaced':0.0,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':100})
-
- - cd: tbl.count()
- ot: 100
-
- - py: tbl2.insert([{'id':i, 'foo':{'bar':i}} for i in xrange(100)])
- js: |
- tbl2.insert(function(){
- var res = []
- for (var i = 0; i < 100; i++) {
- res.push({id:i,foo:{bar:i}});
- }
- return res;
- }())
- rb: tbl2.insert((0...100).map{ |i| { :id => i, :foo => { :bar => i } } })
- ot: ({'deleted':0.0,'replaced':0.0,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':100})
-
- - cd: tbl2.count()
- ot: 100
-
- # Identity
- - py: tbl.get(12).update(lambda row:row)
- js: tbl.get(12).update(function(row) { return row; })
- rb: tbl.get(12).update{ |row| row}
- ot: {'deleted':0.0,'replaced':0.0,'unchanged':1,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # Soft durability point update
- - py: tbl.get(12).update(lambda row:{'a':row['id'] + 1}, durability='soft')
- js: tbl.get(12).update(function(row) { return {'a':row('id').add(1)}; }, {durability:'soft'})
- rb: tbl.get(12).update({ :durability => 'soft' }) { |row| { :a => row[:id] + 1 } }
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl.get(12)
- ot: {'id':12, 'a':13}
-
- # Hard durability point update
- - py: tbl.get(12).update(lambda row:{'a':row['id'] + 2}, durability='hard')
- js: tbl.get(12).update(function(row) { return {'a':row('id').add(2)}; }, {durability:'hard'})
- rb: tbl.get(12).update({ :durability => 'hard' }) { |row| { :a => row[:id] + 2 } }
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl.get(12)
- ot: {'id':12, 'a':14}
-
- # Wrong durability point update
- - py: tbl.get(12).update(lambda row:{'a':row['id'] + 3}, durability='wrong')
- js: tbl.get(12).update(function(row) { return {'a':row('id').add(3)}; }, {durability:'wrong'})
- rb: tbl.get(12).update({ :durability => 'wrong' }) { |row| { :a => row[:id] + 3 } }
- ot: err('ReqlQueryLogicError', 'Durability option `wrong` unrecognized (options are "hard" and "soft").', [0])
-
- - cd: tbl.get(12)
- ot: {'id':12, 'a':14}
-
- # Point update
- - py: tbl.get(12).update(lambda row:{'a':row['id']})
- js: tbl.get(12).update(function(row) { return {'a':row('id')}; })
- rb: tbl.get(12).update{ |row| { :a => row[:id] } }
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl.get(12)
- ot: {'id':12, 'a':12}
-
- # undo the point update
- - cd: tbl.get(12).update({'a':r.literal()})
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # Update selection of table
-
- - py: tbl.between(10, 20).update(lambda row:{'a':row['id']})
- js: tbl.between(10, 20).update(function(row) { return {'a':row('id')}; })
- rb: tbl.between(10, 20).update{ |row| { :a => row[:id] } }
- ot: {'deleted':0.0,'replaced':10,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - py: tbl.filter(lambda row:(row['id'] >= 10) & (row['id'] < 20)).update(lambda row:{'a':row['id']})
- js: tbl.filter(function(row) { return row('id').ge(10).and(row('id').lt(20))}).update(function(row) { return {'a':row('id')}; })
- rb: tbl.filter{ |row| (row[:id] >= 10).and(row[:id] < 20) }.update{ |row| { :a => row[:id] } }
- ot: {'deleted':0.0,'replaced':0.0,'unchanged':10,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - py: tbl.filter(lambda row:(row['id'] >= 10) & (row['id'] < 20)).update(lambda row:{'b':row['id']})
- js: tbl.filter(function(row) { return row('id').ge(10).and(row('id').lt(20))}).update(function(row) { return {'b':row('id')}; })
- rb: tbl.filter{ |row| (row[:id] >= 10).and(row[:id] < 20) }.update{ |row| { :b => row[:id] } }
- ot: {'deleted':0.0,'replaced':10,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # now undo that update
- - cd: tbl.between(10, 20).update({'a':r.literal()})
- ot: {'deleted':0.0,'replaced':10,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # trying to change pkey of a document
- - cd: tbl.get(1).update({'id':2,'d':1})
- ot: {'first_error':"Primary key `id` cannot be changed (`{\n\t\"id\":\t1\n}` -> `{\n\t\"d\":\t1,\n\t\"id\":\t2\n}`).",'deleted':0.0,'replaced':0.0,'unchanged':0.0,'errors':1,'skipped':0.0,'inserted':0.0}
-
- # check r.row, static value and otherwise
- - py: tbl.get(1).update({'id':r.row['id'],'d':'b'})
- js: tbl.get(1).update({'id':r.row('id'),'d':'b'})
- rb: tbl.get(1).update{ |row| { :id => row[:id], :d => 'b' } }
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # I don't we don't need the merge, just testing r.row just in case
- - cd: tbl.get(1).update(r.row.merge({'d':'b'}))
- rb: tbl.get(1).update{ |row| row.merge({'d':'b'}) }
- ot: {'deleted':0.0,'replaced':0.0,'unchanged':1,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # test atomicity constraints (positive and negative test)
- - cd: tbl.get(1).update({'d':r.js('5')})
- ot: err('ReqlQueryLogicError', 'Could not prove argument deterministic. Maybe you want to use the non_atomic flag?', [0])
-
- - cd: tbl.get(1).update({'d':tbl.nth(0)})
- ot: err('ReqlQueryLogicError', 'Could not prove argument deterministic. Maybe you want to use the non_atomic flag?', [0])
-
- - py: tbl.get(1).update({'d':r.js('5')}, non_atomic=True)
- js: tbl.get(1).update({'d':r.js('5')}, {'nonAtomic':true})
- rb: tbl.get(1).update({ :d => r.js('5') }, { :non_atomic => true })
- ot: {'deleted':0.0,'replaced':1,'unchanged':0.0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - js: tbl.get(1).update({}, 'foo')
- ot: err('ReqlCompileError', 'Expected 1 argument (not including options) but found 2.')
-
- - js: tbl.get(1).update({}, {'foo':'bar'})
- ot: err('ReqlCompileError', 'Unrecognized optional argument `foo`.')
-
- # Update whole table
- - py: tbl.update(lambda row:{'a':row['id']})
- js: tbl.update(function(row) { return {'a':row('id')}; })
- rb: tbl.update{ |row| { :a => row['id'] } }
- ot: {'deleted':0.0,'replaced':100,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # undo the update on the whole table
- - cd: tbl.update({'a':r.literal()})
- ot: {'deleted':0.0,'replaced':100,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- # recursive merge
- - cd: tbl2.update({'foo':{'bar':2}})
- ot: {'deleted':0.0,'replaced':99,'unchanged':1,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl2.update({'foo':r.literal({'bar':2})})
- ot: {'deleted':0.0,'replaced':0,'unchanged':100,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - rb: tbl2.update{|row| {'foo':r.literal({'bar':2})}}
- ot: {'deleted':0.0,'replaced':0,'unchanged':100,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl2.order_by('id').nth(0)
- ot: {'id':0,'foo':{'bar':2}}
-
- - cd: tbl2.update({'foo':{'buzz':2}})
- ot: {'deleted':0.0,'replaced':100,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl2.order_by('id').nth(0)
- ot: {'id':0,'foo':{'bar':2,'buzz':2}}
-
- - cd: tbl2.update({'foo':r.literal(1)})
- ot: {'deleted':0.0,'replaced':100,'unchanged':0,'errors':0.0,'skipped':0.0,'inserted':0.0}
-
- - cd: tbl2.order_by('id').nth(0)
- ot: {'id':0,'foo':1}
-