UNPKG

aerospike

Version:
77 lines (67 loc) 3.04 kB
// ***************************************************************************** // Copyright 2013-2024 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. // ***************************************************************************** 'use strict' /* global expect, describe, it */ /* eslint-disable no-unused-expressions */ import Aerospike, { Client, BatchResult, AerospikeRecord, BatchSelectRecord, Key } from 'aerospike'; import { expect } from 'chai'; import * as helper from './test_helper'; const keygen = helper.keygen const metagen = helper.metagen const recgen = helper.recgen const putgen = helper.putgen const valgen = helper.valgen describe('client.batchSelect()', function () { const client: Client = helper.client it('should successfully read bins from 10 records', function () { const numberOfRecords: number = 10 const generators: any = { keygen: keygen.string(helper.namespace, helper.set, { prefix: 'test/batch_get/success', random: false }), recgen: recgen.record({ i: valgen.integer(), s: valgen.string(), b: valgen.bytes() }), metagen: metagen.constant({ ttl: 1000 }) } return putgen.put(numberOfRecords, generators) .then((records: AerospikeRecord[]) => { const keys = records.map((record: AerospikeRecord) => record.key) return client.batchSelect(keys, ['i', 's']) }) .then((results: BatchResult[]) => { expect(results.length).to.equal(numberOfRecords) results.forEach((result: BatchResult) => { expect(result.status).to.equal(Aerospike.status.OK) expect(result.record.bins).to.have.all.keys('i', 's') }) }) }) it('should fail reading bins from non-existent records', function (done) { const numberOfRecords = 10 const kgen: any = keygen.string(helper.namespace, helper.set, { prefix: 'test/batch_get/fail', random: false }) const keys: Key[] = keygen.range(kgen, numberOfRecords) const bins: string[] = ['i', 's'] client.batchSelect(keys, bins, function (err?: Error, results?: BatchSelectRecord[]) { expect(err).not.to.be.ok expect(results?.length).to.equal(numberOfRecords) results?.forEach(function (result: BatchSelectRecord) { expect(result.status).to.equal(Aerospike.status.ERR_RECORD_NOT_FOUND) }) done() }) }) it('returns an empty array when no keys are passed', () => { client.batchSelect([], ['i']) .then((results: BatchSelectRecord[]) => expect(results).to.eql([])) }) })