First commit
This commit is contained in:
5
node_modules/ldapjs/test-integration/.eslintrc.js
generated
vendored
Normal file
5
node_modules/ldapjs/test-integration/.eslintrc.js
generated
vendored
Normal file
@ -0,0 +1,5 @@
|
||||
module.exports = {
|
||||
rules: {
|
||||
'no-shadow': 'off'
|
||||
}
|
||||
}
|
||||
21
node_modules/ldapjs/test-integration/client/connect.test.js
generated
vendored
Normal file
21
node_modules/ldapjs/test-integration/client/connect.test.js
generated
vendored
Normal file
@ -0,0 +1,21 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
tap.test('connects to a server', t => {
|
||||
t.plan(2)
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
client.bind('cn=Philip J. Fry,ou=people,dc=planetexpress,dc=com', 'fry', (err) => {
|
||||
t.error(err)
|
||||
t.pass()
|
||||
client.unbind()
|
||||
})
|
||||
})
|
||||
95
node_modules/ldapjs/test-integration/client/issue-860.test.js
generated
vendored
Normal file
95
node_modules/ldapjs/test-integration/client/issue-860.test.js
generated
vendored
Normal file
@ -0,0 +1,95 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
const parseDN = ldapjs.parseDN
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
|
||||
tap.before(() => {
|
||||
return new Promise((resolve, reject) => {
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
if (err) {
|
||||
return reject(err)
|
||||
}
|
||||
resolve()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
tap.teardown(() => {
|
||||
client.unbind()
|
||||
})
|
||||
|
||||
tap.test('can search OUs with Japanese characters', t => {
|
||||
t.plan(2)
|
||||
|
||||
const opts = {
|
||||
filter: '(&(objectClass=person))',
|
||||
scope: 'sub',
|
||||
paged: true,
|
||||
sizeLimit: 100,
|
||||
attributes: ['cn', 'employeeID']
|
||||
}
|
||||
|
||||
const baseDN = parseDN('ou=テスト,dc=planetexpress,dc=com')
|
||||
|
||||
client.search(baseDN.toString(), opts, (err, res) => {
|
||||
t.error(err, 'search error')
|
||||
res.on('searchEntry', (entry) => {
|
||||
t.match(entry.pojo, {
|
||||
type: 'SearchResultEntry',
|
||||
objectName: 'cn=jdoe,ou=\\e3\\83\\86\\e3\\82\\b9\\e3\\83\\88,dc=planetexpress,dc=com',
|
||||
attributes: [{
|
||||
type: 'cn',
|
||||
values: ['John', 'jdoe']
|
||||
}]
|
||||
})
|
||||
})
|
||||
res.on('error', (err) => {
|
||||
t.error(err, 'search entry error')
|
||||
})
|
||||
res.on('end', () => {
|
||||
t.end()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
tap.test('can search with non-ascii chars in filter', t => {
|
||||
t.plan(3)
|
||||
|
||||
const opts = {
|
||||
filter: '(&(sn=Rodríguez))',
|
||||
scope: 'sub',
|
||||
attributes: ['dn', 'sn', 'cn'],
|
||||
type: 'user'
|
||||
}
|
||||
|
||||
let searchEntryCount = 0
|
||||
client.search('dc=planetexpress,dc=com', opts, (err, res) => {
|
||||
t.error(err, 'search error')
|
||||
res.on('searchEntry', (entry) => {
|
||||
searchEntryCount += 1
|
||||
t.match(entry.pojo, {
|
||||
type: 'SearchResultEntry',
|
||||
objectName: 'cn=Bender Bending Rodr\\c3\\adguez,ou=people,dc=planetexpress,dc=com',
|
||||
attributes: [{
|
||||
type: 'cn',
|
||||
values: ['Bender Bending Rodríguez']
|
||||
}]
|
||||
})
|
||||
})
|
||||
res.on('error', (err) => {
|
||||
t.error(err, 'search entry error')
|
||||
})
|
||||
res.on('end', () => {
|
||||
t.equal(searchEntryCount, 1, 'should have found 1 entry')
|
||||
t.end()
|
||||
})
|
||||
})
|
||||
})
|
||||
56
node_modules/ldapjs/test-integration/client/issue-883.test.js
generated
vendored
Normal file
56
node_modules/ldapjs/test-integration/client/issue-883.test.js
generated
vendored
Normal file
@ -0,0 +1,56 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
|
||||
tap.test('adds entries with Korean characters', t => {
|
||||
t.plan(4)
|
||||
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
t.error(err, 'bind error')
|
||||
})
|
||||
|
||||
const nm = '홍길동'
|
||||
const dn = `cn=${nm},ou=people,dc=planetexpress,dc=com`
|
||||
const entry = {
|
||||
objectclass: 'person',
|
||||
sn: 'korean test'
|
||||
}
|
||||
|
||||
client.add(dn, entry, err => {
|
||||
t.error(err, 'add entry error')
|
||||
|
||||
const searchOpts = {
|
||||
filter: '(sn=korean test)',
|
||||
scope: 'subtree',
|
||||
attributes: ['cn', 'sn'],
|
||||
sizeLimit: 10,
|
||||
timeLimit: 0
|
||||
}
|
||||
client.search('ou=people,dc=planetexpress,dc=com', searchOpts, (err, res) => {
|
||||
t.error(err, 'search error')
|
||||
|
||||
res.on('searchEntry', (entry) => {
|
||||
t.equal(
|
||||
entry.attributes.filter(a => a.type === 'cn').pop().values.pop(),
|
||||
nm
|
||||
)
|
||||
})
|
||||
|
||||
res.on('error', (err) => {
|
||||
t.error(err, 'search entry error')
|
||||
})
|
||||
|
||||
res.on('end', () => {
|
||||
client.unbind(t.end)
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
55
node_modules/ldapjs/test-integration/client/issue-885.test.js
generated
vendored
Normal file
55
node_modules/ldapjs/test-integration/client/issue-885.test.js
generated
vendored
Normal file
@ -0,0 +1,55 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
const parseDN = ldapjs.parseDN
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
|
||||
const searchOpts = {
|
||||
filter: '(&(objectClass=person))',
|
||||
scope: 'sub',
|
||||
paged: true,
|
||||
sizeLimit: 0,
|
||||
attributes: ['cn', 'employeeID']
|
||||
}
|
||||
|
||||
const baseDN = parseDN('ou=large_ou,dc=planetexpress,dc=com')
|
||||
|
||||
tap.test('paged search option returns pages', t => {
|
||||
t.plan(4)
|
||||
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
t.error(err, 'bind error')
|
||||
})
|
||||
|
||||
client.search(baseDN.toString(), searchOpts, (err, res) => {
|
||||
t.error(err, 'search error')
|
||||
|
||||
let pages = 0
|
||||
const results = []
|
||||
res.on('searchEntry', (entry) => {
|
||||
results.push(entry)
|
||||
})
|
||||
|
||||
res.on('page', () => {
|
||||
pages += 1
|
||||
})
|
||||
|
||||
res.on('error', (err) => {
|
||||
t.error(err, 'search entry error')
|
||||
})
|
||||
|
||||
res.on('end', () => {
|
||||
t.equal(results.length, 2000)
|
||||
t.equal(pages, 20)
|
||||
|
||||
client.unbind(t.end)
|
||||
})
|
||||
})
|
||||
})
|
||||
91
node_modules/ldapjs/test-integration/client/issue-923.test.js
generated
vendored
Normal file
91
node_modules/ldapjs/test-integration/client/issue-923.test.js
generated
vendored
Normal file
@ -0,0 +1,91 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
const { DN } = require('@ldapjs/dn')
|
||||
const Change = require('@ldapjs/change')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
|
||||
tap.teardown(() => {
|
||||
client.unbind()
|
||||
})
|
||||
|
||||
tap.test('modifies entry specified by dn string', t => {
|
||||
t.plan(4)
|
||||
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
t.error(err, 'bind error')
|
||||
})
|
||||
|
||||
const dn = 'cn=large10,ou=large_ou,dc=planetexpress,dc=com'
|
||||
const change = new Change({
|
||||
operation: 'replace',
|
||||
modification: {
|
||||
type: 'givenName',
|
||||
values: ['test']
|
||||
}
|
||||
})
|
||||
|
||||
client.modify(dn, change, (err) => {
|
||||
t.error(err, 'modify error')
|
||||
validateChange({ t, expected: 'test', client })
|
||||
})
|
||||
})
|
||||
|
||||
tap.test('modifies entry specified by dn object', t => {
|
||||
t.plan(4)
|
||||
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
t.error(err, 'bind error')
|
||||
})
|
||||
|
||||
const dn = DN.fromString('cn=large10,ou=large_ou,dc=planetexpress,dc=com')
|
||||
const change = new Change({
|
||||
operation: 'replace',
|
||||
modification: {
|
||||
type: 'givenName',
|
||||
values: ['test2']
|
||||
}
|
||||
})
|
||||
|
||||
client.modify(dn, change, (err) => {
|
||||
t.error(err, 'modify error')
|
||||
validateChange({ t, expected: 'test2', client })
|
||||
})
|
||||
})
|
||||
|
||||
function validateChange ({ t, expected, client }) {
|
||||
const searchBase = 'ou=large_ou,dc=planetexpress,dc=com'
|
||||
const searchOpts = {
|
||||
filter: '(cn=large10)',
|
||||
scope: 'subtree',
|
||||
attributes: ['givenName'],
|
||||
sizeLimit: 10,
|
||||
timeLimit: 0
|
||||
}
|
||||
|
||||
client.search(searchBase, searchOpts, (err, res) => {
|
||||
t.error(err, 'search error')
|
||||
|
||||
res.on('searchEntry', entry => {
|
||||
t.equal(
|
||||
entry.attributes.filter(a => a.type === 'givenName').pop().values.pop(),
|
||||
expected
|
||||
)
|
||||
})
|
||||
|
||||
res.on('error', err => {
|
||||
t.error(err, 'search entry error')
|
||||
})
|
||||
|
||||
res.on('end', () => {
|
||||
t.end()
|
||||
})
|
||||
})
|
||||
}
|
||||
81
node_modules/ldapjs/test-integration/client/issue-940.test.js
generated
vendored
Normal file
81
node_modules/ldapjs/test-integration/client/issue-940.test.js
generated
vendored
Normal file
@ -0,0 +1,81 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
const Change = require('@ldapjs/change')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
|
||||
tap.before(() => {
|
||||
return new Promise((resolve, reject) => {
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err) => {
|
||||
if (err) {
|
||||
return reject(err)
|
||||
}
|
||||
resolve()
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
tap.teardown(() => {
|
||||
client.unbind()
|
||||
})
|
||||
|
||||
tap.test('can modify entries with non-ascii chars in RDN', t => {
|
||||
t.plan(6)
|
||||
|
||||
const dn = 'cn=Mendonça,ou=people,dc=planetexpress,dc=com'
|
||||
const entry = {
|
||||
objectclass: 'person',
|
||||
sn: 'change me'
|
||||
}
|
||||
|
||||
client.add(dn, entry, error => {
|
||||
t.error(error, 'add should not error')
|
||||
doSearch('change me', doModify)
|
||||
})
|
||||
|
||||
function doModify () {
|
||||
const change = new Change({
|
||||
operation: 'replace',
|
||||
modification: {
|
||||
type: 'sn',
|
||||
values: ['changed']
|
||||
}
|
||||
})
|
||||
|
||||
client.modify(dn, change, (error) => {
|
||||
t.error(error, 'modify should not error')
|
||||
doSearch('changed', t.end.bind(t))
|
||||
})
|
||||
}
|
||||
|
||||
function doSearch (expected, callback) {
|
||||
const searchOpts = {
|
||||
filter: '(&(objectclass=person)(cn=Mendonça))',
|
||||
scope: 'subtree',
|
||||
attributes: ['sn']
|
||||
}
|
||||
client.search('ou=people,dc=planetexpress,dc=com', searchOpts, (error, res) => {
|
||||
t.error(error, 'search should not error')
|
||||
|
||||
res.on('searchEntry', entry => {
|
||||
const found = entry.attributes.filter(a => a.type === 'sn').pop().values.pop()
|
||||
t.equal(found, expected, `expected '${expected}' and got '${found}'`)
|
||||
})
|
||||
|
||||
res.on('error', error => {
|
||||
t.error(error, 'search result processing should not error')
|
||||
})
|
||||
|
||||
res.on('end', () => {
|
||||
callback()
|
||||
})
|
||||
})
|
||||
}
|
||||
})
|
||||
87
node_modules/ldapjs/test-integration/client/issue-946.test.js
generated
vendored
Normal file
87
node_modules/ldapjs/test-integration/client/issue-946.test.js
generated
vendored
Normal file
@ -0,0 +1,87 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
tap.test('can use password policy response', t => {
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
const targetDN = 'cn=Bender Bending Rodríguez,ou=people,dc=planetexpress,dc=com'
|
||||
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', (err, res) => {
|
||||
t.error(err)
|
||||
t.ok(res)
|
||||
t.equal(res.status, 0)
|
||||
|
||||
const newPassword = 'bender2'
|
||||
changePassword(client, newPassword, () => {
|
||||
client.unbind()
|
||||
bindNewClient(newPassword, { error: 2 }, (client) => {
|
||||
const newPassword = 'bender'
|
||||
changePassword(client, newPassword, () => {
|
||||
client.unbind()
|
||||
bindNewClient(newPassword, { timeBeforeExpiration: 1000 }, (client) => {
|
||||
client.unbind(t.end)
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
function bindNewClient (pwd, expected, callback) {
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
const control = new ldapjs.PasswordPolicyControl()
|
||||
|
||||
client.bind(targetDN, pwd, control, (err, res) => {
|
||||
t.error(err)
|
||||
t.ok(res)
|
||||
t.equal(res.status, 0)
|
||||
|
||||
let error = null
|
||||
let timeBeforeExpiration = null
|
||||
let graceAuthNsRemaining = null
|
||||
|
||||
res.controls.forEach(control => {
|
||||
if (control.type === ldapjs.PasswordPolicyControl.OID) {
|
||||
error = control.value.error ?? error
|
||||
timeBeforeExpiration = control.value.timeBeforeExpiration ?? timeBeforeExpiration
|
||||
graceAuthNsRemaining = control.value.graceAuthNsRemaining ?? graceAuthNsRemaining
|
||||
}
|
||||
})
|
||||
|
||||
if (expected.error !== undefined) {
|
||||
t.equal(error, expected.error)
|
||||
}
|
||||
if (expected.timeBeforeExpiration !== undefined) {
|
||||
t.equal(timeBeforeExpiration, expected.timeBeforeExpiration)
|
||||
}
|
||||
if (expected.graceAuthNsRemaining !== undefined) {
|
||||
t.equal(graceAuthNsRemaining, expected.graceAuthNsRemaining)
|
||||
}
|
||||
|
||||
callback(client)
|
||||
})
|
||||
}
|
||||
|
||||
function changePassword (client, newPwd, callback) {
|
||||
const change = new ldapjs.Change({
|
||||
operation: 'replace',
|
||||
modification: new ldapjs.Attribute({
|
||||
type: 'userPassword',
|
||||
values: newPwd
|
||||
})
|
||||
})
|
||||
|
||||
client.modify(targetDN, change, (err, res) => {
|
||||
t.error(err)
|
||||
t.ok(res)
|
||||
t.equal(res.status, 0)
|
||||
|
||||
callback()
|
||||
})
|
||||
}
|
||||
})
|
||||
98
node_modules/ldapjs/test-integration/client/issues.test.js
generated
vendored
Normal file
98
node_modules/ldapjs/test-integration/client/issues.test.js
generated
vendored
Normal file
@ -0,0 +1,98 @@
|
||||
'use strict'
|
||||
|
||||
const tap = require('tap')
|
||||
const ldapjs = require('../../lib')
|
||||
|
||||
const SCHEME = process.env.SCHEME || 'ldap'
|
||||
const HOST = process.env.HOST || '127.0.0.1'
|
||||
const PORT = process.env.PORT || 389
|
||||
|
||||
const baseURL = `${SCHEME}://${HOST}:${PORT}`
|
||||
|
||||
tap.test('modifyDN with long name (issue #480)', t => {
|
||||
// 2023-08-15: disabling this 265 character string until a bug can be
|
||||
// fixed in OpenLDAP. See https://github.com/ldapjs/docker-test-openldap/blob/d48bc2fb001b4ed9a152715ced4a2cb120439ec4/bootstrap/slapd-init.sh#L19-L31.
|
||||
// const longStr = 'a292979f2c86d513d48bbb9786b564b3c5228146e5ba46f404724e322544a7304a2b1049168803a5485e2d57a544c6a0d860af91330acb77e5907a9e601ad1227e80e0dc50abe963b47a004f2c90f570450d0e920d15436fdc771e3bdac0487a9735473ed3a79361d1778d7e53a7fb0e5f01f97a75ef05837d1d5496fc86968ff47fcb64'
|
||||
|
||||
// 2023-08-15: this 140 character string satisfies the original issue
|
||||
// (https://github.com/ldapjs/node-ldapjs/issues/480) and avoids a bug
|
||||
// in OpenLDAP 2.5.
|
||||
const longStr = '292979f2c86d513d48bbb9786b564b3c5228146e5ba46f404724e322544a7304a2b1049168803a5485e2d57a544c6a0d860af91330acb77e5907a9e601ad1227e80e0dc50ab'
|
||||
const targetDN = 'cn=Turanga Leela,ou=people,dc=planetexpress,dc=com'
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com', 'GoodNewsEveryone', bindHandler)
|
||||
|
||||
function bindHandler (err) {
|
||||
t.error(err)
|
||||
client.modifyDN(
|
||||
targetDN,
|
||||
`cn=${longStr},ou=people,dc=planetexpress,dc=com`,
|
||||
modifyHandler
|
||||
)
|
||||
}
|
||||
|
||||
function modifyHandler (err, res) {
|
||||
t.error(err)
|
||||
t.ok(res)
|
||||
t.equal(res.status, 0)
|
||||
|
||||
client.modifyDN(
|
||||
`cn=${longStr},ou=people,dc=planetexpress,dc=com`,
|
||||
targetDN,
|
||||
(err) => {
|
||||
t.error(err)
|
||||
client.unbind(t.end)
|
||||
}
|
||||
)
|
||||
}
|
||||
})
|
||||
|
||||
tap.test('whois works correctly (issue #370)', t => {
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
client.bind('cn=Philip J. Fry,ou=people,dc=planetexpress,dc=com', 'fry', (err) => {
|
||||
t.error(err)
|
||||
|
||||
client.exop('1.3.6.1.4.1.4203.1.11.3', (err, value, res) => {
|
||||
t.error(err)
|
||||
t.ok(value)
|
||||
t.equal(value, 'dn:cn=Philip J. Fry,ou=people,dc=planetexpress,dc=com')
|
||||
t.ok(res)
|
||||
t.equal(res.status, 0)
|
||||
|
||||
client.unbind(t.end)
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
tap.test('can access large groups (issue #582)', t => {
|
||||
const client = ldapjs.createClient({ url: baseURL })
|
||||
client.bind('cn=admin,dc=planetexpress,dc=com ', 'GoodNewsEveryone', (err) => {
|
||||
t.error(err)
|
||||
const searchOpts = {
|
||||
scope: 'sub',
|
||||
filter: '(&(objectClass=group)(cn=large_group))'
|
||||
}
|
||||
client.search('ou=large_ou,dc=planetexpress,dc=com', searchOpts, (err, response) => {
|
||||
t.error(err)
|
||||
|
||||
const results = []
|
||||
response.on('searchEntry', (entry) => {
|
||||
results.push(entry)
|
||||
})
|
||||
response.on('error', t.error)
|
||||
response.on('end', (result) => {
|
||||
t.equal(result.status, 0)
|
||||
t.equal(results.length === 1, true)
|
||||
t.ok(results[0].attributes)
|
||||
|
||||
const memberAttr = results[0].attributes.find(a => a.type === 'member')
|
||||
t.ok(memberAttr)
|
||||
t.ok(memberAttr.values)
|
||||
t.type(memberAttr.values, Array)
|
||||
t.equal(memberAttr.values.length, 2000)
|
||||
|
||||
client.unbind(t.end)
|
||||
})
|
||||
})
|
||||
})
|
||||
})
|
||||
Reference in New Issue
Block a user