This repository has been archived on 2025-09-14. You can view files and clone it, but cannot push or open issues or pull requests.
Files
zhangyang-zerotierone/ext/librethinkdbxx/test/upstream/mutation/update.yaml
2017-11-02 07:05:11 -07:00

171 lines
7.7 KiB
YAML

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}