aerospike
Version:
Aerospike Client Library
142 lines (118 loc) • 4.82 kB
text/typescript
// *****************************************************************************
// Copyright 2022-2023 Aerospike, Inc.
//
// Licensed under the Apache License, Version 2.0 (the "License")
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
// *****************************************************************************
/* eslint-env mocha */
/* global expect */
/* eslint-disable no-unused-expressions */
import Aerospike, { Client, AerospikeRecord, BatchResult, Key as K, UDF, BatchPolicyOptions, BatchApplyPolicyOptions, WritePolicyOptions, ConfigOptions, AerospikeError, status} from 'aerospike';
import * as helper from './test_helper';
import { expect, assert} from 'chai';
// const util = require('util')
const keygen = helper.keygen
const metagen = helper.metagen
const recgen = helper.recgen
const putgen = helper.putgen
const valgen = helper.valgen
const Key: typeof K = Aerospike.Key
describe('client.batchApply()', function () {
const client = helper.client
before(async function () {
const nrecords: number = 10
const generators: any = {
keygen: keygen.string(helper.namespace, helper.set, { prefix: 'test/batch_apply/', random: false }),
recgen: recgen.record({
i: valgen.integer(),
s: valgen.string(),
str2: valgen.string('hello'),
l: () => [1, 2, 3],
m: () => { return { a: 1, b: 2, c: 3 } }
}),
metagen: metagen.constant({ ttl: 1000 })
}
await helper.udf.register('udf.lua')
await putgen.put(nrecords, generators, {})
return
})
context('with failure', function () {
helper.skipUnlessVersion('>= 6.0.0', this)
it('apply udf on batch of records', function (done) {
const batchRecords: K[] = [
new Key(helper.namespace, helper.set, 'test/batch_apply/1'),
new Key(helper.namespace, helper.set, 'test/batch_apply/2'),
new Key(helper.namespace, helper.set, 'test/batch_apply/3'),
new Key(helper.namespace, helper.set, 'test/batch_apply/4'),
new Key(helper.namespace, helper.set, 'test/batch_apply/5')
]
const policy: BatchPolicyOptions = new Aerospike.BatchPolicy({
totalTimeout: 1500
})
const udf: UDF = {
module: 'udf',
funcname: 'withArguments',
args: [[1, 2, 3]]
}
client.batchApply(batchRecords, udf, policy, function (err?: Error, results?: BatchResult[]) {
expect(err).not.to.be.ok
expect(results?.length).to.equal(5)
results?.forEach(function (result: any) {
// console.log(util.inspect(result, true, 10, true))
expect(result.status).to.equal(Aerospike.status.OK)
expect(result.record.bins.SUCCESS).to.eql([1, 2, 3])
})
done()
})
})
})
context('with BatchApplyPolicy', function () {
helper.skipUnlessVersionAndEnterprise('>= 8.0.0', this)
helper.skipUnlessStrongConsistency(this)
it('onLockingOnly should fail when writing to a locked record', async function () {
const batchRecords: K[] = [
new Key(helper.namespace, helper.set, 'test/batch_apply/6'),
new Key(helper.namespace, helper.set, 'test/batch_apply/7'),
]
let mrt: any = new Aerospike.Transaction()
// await client.remove(batchRecords[0])
// await client.remove(batchRecords[1])
await client.put(batchRecords[0], { foo: 'bar' }, { ttl: 1000 })
await client.put(batchRecords[1], { foo: 'bar' }, { ttl: 1000 })
const policyBatch: BatchPolicyOptions = new Aerospike.BatchPolicy({
txn: mrt,
})
const policyBatchApply: BatchApplyPolicyOptions = new Aerospike.BatchApplyPolicy({
onLockingOnly: true,
})
const udf: UDF = {
module: 'udf',
funcname: 'updateRecord',
args: ['foo', 50]
}
await client.batchApply(batchRecords, udf, policyBatch, policyBatchApply)
try {
await client.batchApply(batchRecords, udf, policyBatch, policyBatchApply)
assert.fail('An error should have been caught')
}
catch(error: any){
expect(error).to.be.instanceof(AerospikeError).with.property('code', status.BATCH_FAILED)
let exists = await client.get(batchRecords[0])
expect(exists.bins.foo).to.eql('bar')
}
finally{
await client.abort(mrt)
}
})
})
})