Skip to content

Commit

Permalink
ci: pull in misc CI fixes for the 4x branch (#3536)
Browse files Browse the repository at this point in the history
  • Loading branch information
baileympearson authored Jan 23, 2023
1 parent eb5f651 commit 4c49b2e
Show file tree
Hide file tree
Showing 14 changed files with 97 additions and 65 deletions.
14 changes: 11 additions & 3 deletions .evergreen/config.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2204,7 +2204,7 @@ tasks:
- func: bootstrap kms servers
- func: run custom csfle tests
vars:
CSFLE_GIT_REF: 5745f374109346a2597405f2251a178d463a14e1
CSFLE_GIT_REF: ff9e095eaf72f9e442761f69080dae159a395d94
- name: run-custom-csfle-tests-5.0-master
tags:
- run-custom-dependency-tests
Expand Down Expand Up @@ -2234,7 +2234,7 @@ tasks:
- func: bootstrap kms servers
- func: run custom csfle tests
vars:
CSFLE_GIT_REF: 5745f374109346a2597405f2251a178d463a14e1
CSFLE_GIT_REF: ff9e095eaf72f9e442761f69080dae159a395d94
- name: run-custom-csfle-tests-rapid-master
tags:
- run-custom-dependency-tests
Expand Down Expand Up @@ -2264,7 +2264,7 @@ tasks:
- func: bootstrap kms servers
- func: run custom csfle tests
vars:
CSFLE_GIT_REF: 5745f374109346a2597405f2251a178d463a14e1
CSFLE_GIT_REF: ff9e095eaf72f9e442761f69080dae159a395d94
- name: run-custom-csfle-tests-latest-master
tags:
- run-custom-dependency-tests
Expand Down Expand Up @@ -2868,10 +2868,13 @@ buildvariants:
- test-3.6-sharded_cluster
- test-latest-server-v1-api
- test-atlas-connectivity
- test-atlas-data-lake
- test-5.0-load-balanced
- test-6.0-load-balanced
- test-latest-load-balanced
- test-auth-ldap
- test-socks5
- test-socks5-tls
- test-tls-support-latest
- test-tls-support-6.0
- test-tls-support-5.0
Expand Down Expand Up @@ -2910,10 +2913,12 @@ buildvariants:
- test-3.6-sharded_cluster
- test-latest-server-v1-api
- test-atlas-connectivity
- test-atlas-data-lake
- test-5.0-load-balanced
- test-6.0-load-balanced
- test-latest-load-balanced
- test-auth-ldap
- test-socks5-tls
- test-tls-support-latest
- test-tls-support-6.0
- test-tls-support-5.0
Expand Down Expand Up @@ -3075,6 +3080,9 @@ buildvariants:
- test-3.6-replica_set
- test-3.6-sharded_cluster
- test-latest-server-v1-api
- test-atlas-data-lake
- test-socks5
- test-socks5-tls
- test-tls-support-latest
- test-tls-support-6.0
- test-tls-support-5.0
Expand Down
33 changes: 10 additions & 23 deletions .evergreen/generate_evergreen_tasks.js
Original file line number Diff line number Diff line change
Expand Up @@ -623,7 +623,7 @@ const oneOffFuncAsTasks = oneOffFuncs.map(oneOffFunc => ({
}));

for (const version of ['5.0', 'rapid', 'latest']) {
for (const ref of ['5745f374109346a2597405f2251a178d463a14e1', 'master']) {
for (const ref of ['ff9e095eaf72f9e442761f69080dae159a395d94', 'master']) {
oneOffFuncAsTasks.push({
name: `run-custom-csfle-tests-${version}-${ref === 'master' ? ref : 'pinned-commit'}`,
tags: ['run-custom-dependency-tests'],
Expand Down Expand Up @@ -704,41 +704,28 @@ BUILD_VARIANTS.push({

// TODO(NODE-4575): unskip zstd and snappy on node 16
for (const variant of BUILD_VARIANTS.filter(
variant => variant.expansions && variant.expansions.NODE_LTS_NAME === 'gallium'
variant => variant.expansions && ['gallium', 'hydrogen', 'latest'].includes(variant.expansions.NODE_LTS_NAME)
)) {
variant.tasks = variant.tasks.filter(
name => !['test-zstd-compression', 'test-snappy-compression'].includes(name)
);
}

// TODO(NODE-4667): debug failing tests on Node18
// TODO(NODE-4894): fix kerberos tests on Node18
for (const variant of BUILD_VARIANTS.filter(
variant => variant.expansions && variant.expansions.NODE_LTS_NAME === 'hydrogen'
variant => variant.expansions && ['hydrogen', 'latest'].includes(variant.expansions.NODE_LTS_NAME)
)) {
variant.tasks = variant.tasks.filter(
name => ![
'test-zstd-compression',
'test-snappy-compression',
'test-atlas-data-lake',
'test-socks5',
'test-socks5-tls',
'test-auth-kerberos'
].includes(name)
name => !['test-auth-kerberos'].includes(name)
);
}

// TODO(NODE-4667): debug failing tests on Node18
// latest is currently Node19, so these tests fail
for (const variant of BUILD_VARIANTS.filter(({ name }) => name.includes('node-latest'))) {
// TODO(NODE-4897): Debug socks5 tests on node latest
for (const variant of BUILD_VARIANTS.filter(
variant => variant.expansions && ['latest'].includes(variant.expansions.NODE_LTS_NAME)
)) {
variant.tasks = variant.tasks.filter(
name => ![
'test-zstd-compression',
'test-snappy-compression',
'test-atlas-data-lake',
'test-socks5',
'test-socks5-tls',
'test-auth-kerberos'
].includes(name)
name => !['test-socks5'].includes(name)
);
}

Expand Down
1 change: 0 additions & 1 deletion .evergreen/run-custom-csfle-tests.sh
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,6 @@ popd # mongo-c-driver
pushd libmongocrypt/bindings/node

npm install --production --ignore-scripts
source ./.evergreen/find_cmake.sh
bash ./etc/build-static.sh

popd # libmongocrypt/bindings/node
Expand Down
4 changes: 2 additions & 2 deletions .evergreen/run-kms-servers.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,6 @@ cd ${DRIVERS_TOOLS}/.evergreen/csfle
. ./activate-kmstlsvenv.sh
# by default it always runs on port 5698
./kmstlsvenv/bin/python3 -u kms_kmip_server.py &
./kmstlsvenv/bin/python3 -u kms_http_server.py --ca_file ../x509gen/ca.pem --cert_file ../x509gen/expired.pem --port 8000 &
./kmstlsvenv/bin/python3 -u kms_http_server.py --ca_file ../x509gen/ca.pem --cert_file ../x509gen/wrong-host.pem --port 8001 &
./kmstlsvenv/bin/python3 -u kms_http_server.py --ca_file ../x509gen/ca.pem --cert_file ../x509gen/expired.pem --port 8000 &
./kmstlsvenv/bin/python3 -u kms_http_server.py --ca_file ../x509gen/ca.pem --cert_file ../x509gen/wrong-host.pem --port 8001 &
./kmstlsvenv/bin/python3 -u kms_http_server.py --ca_file ../x509gen/ca.pem --cert_file ../x509gen/server.pem --port 8002 --require_client_cert &
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ const BSON = require('bson');
const { EJSON } = require('bson');
const { expect } = require('chai');
const { getEncryptExtraOptions } = require('../../tools/utils');
const { installNode18DNSHooks } = require('../../tools/runner/hooks/configuration');
const { installNodeDNSWorkaroundHooks } = require('../../tools/runner/hooks/configuration');

describe('Client Side Encryption Prose Corpus Test', function () {
const metadata = {
Expand Down Expand Up @@ -148,7 +148,7 @@ describe('Client Side Encryption Prose Corpus Test', function () {
}
}

installNode18DNSHooks();
installNodeDNSWorkaroundHooks();

before(function () {
// 1. Create a MongoClient without encryption enabled (referred to as ``client``).
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ const util = require('util');
const fs = require('fs');
const path = require('path');
const { getEncryptExtraOptions } = require('../../tools/utils');
const { installNode18DNSHooks } = require('../../tools/runner/hooks/configuration');
const { installNodeDNSWorkaroundHooks } = require('../../tools/runner/hooks/configuration');

/* REFERENCE: (note commit hash) */
/* https://github.com/mongodb/specifications/blob/b3beada72ae1c992294ae6a8eea572003a274c35/source/client-side-encryption/tests/README.rst#deadlock-tests */
Expand Down Expand Up @@ -93,8 +93,7 @@ function deadlockTests(_metadata) {
const metadata = { ..._metadata, requires: { ..._metadata.requires, auth: 'disabled' } };
metadata.skipReason = 'TODO: NODE-3891 - fix tests broken when AUTH enabled';
describe('Connection Pool Deadlock Prevention', function () {
installNode18DNSHooks();

installNodeDNSWorkaroundHooks();
beforeEach(function () {
try {
const mongodbClientEncryption = this.configuration.mongodbClientEncryption;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ const { EJSON, Binary } = BSON;
const { LEGACY_HELLO_COMMAND } = require('../../../src/constants');
const { MongoNetworkError, MongoServerError } = require('../../../src/error');
const { getEncryptExtraOptions } = require('../../tools/utils');
const { installNode18DNSHooks } = require('../../tools/runner/hooks/configuration');
const { installNodeDNSWorkaroundHooks } = require('../../tools/runner/hooks/configuration');
const { coerce, gte } = require('semver');

const getKmsProviders = (localKey, kmipEndpoint, azureEndpoint, gcpEndpoint) => {
const result = BSON.EJSON.parse(process.env.CSFLE_KMS_PROVIDERS || '{}');
Expand Down Expand Up @@ -70,7 +71,7 @@ describe('Client Side Encryption Prose Tests', metadata, function () {
'base64'
);

installNode18DNSHooks();
installNodeDNSWorkaroundHooks();

describe('Data key and double encryption', function () {
// Data key and double encryption
Expand Down Expand Up @@ -1412,6 +1413,10 @@ describe('Client Side Encryption Prose Tests', metadata, function () {
const masterKey = {};

it('should fail with no TLS', metadata, async function () {
if (gte(coerce(process.version), coerce('19'))) {
this.skip('TODO(NODE-4942): fix failing csfle kmip test on Node19+');
return;
}
try {
await clientEncryptionNoTls.createDataKey('kmip', { masterKey });
expect.fail('it must fail with no tls');
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
import * as path from 'path';

import { loadSpecTests } from '../../spec';
import { installNode18DNSHooks } from '../../tools/runner/hooks/configuration';
import { installNodeDNSWorkaroundHooks } from '../../tools/runner/hooks/configuration';
import {
gatherTestSuites,
generateTopologyTests,
Expand Down Expand Up @@ -73,8 +73,7 @@ describe('Client Side Encryption (Legacy)', function () {
testContext
);

installNode18DNSHooks();

installNodeDNSWorkaroundHooks();
after(() => testContext.teardown());
before(function () {
return testContext.setup(this.configuration);
Expand All @@ -98,7 +97,7 @@ describe('Client Side Encryption (Legacy)', function () {
});

describe('Client Side Encryption (Unified)', function () {
installNode18DNSHooks();
installNodeDNSWorkaroundHooks();
runUnifiedSuite(loadSpecTests(path.join('client-side-encryption', 'tests', 'unified')), () =>
isServerless ? 'Unified CSFLE tests to not run on serverless' : false
);
Expand Down
4 changes: 2 additions & 2 deletions test/integration/client-side-encryption/driver.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import * as crypto from 'crypto';

import { Collection, CommandStartedEvent, MongoClient } from '../../../src';
import * as BSON from '../../../src/bson';
import { installNode18DNSHooks } from '../../tools/runner/hooks/configuration';
import { installNodeDNSWorkaroundHooks } from '../../tools/runner/hooks/configuration';
import { ClientEncryption } from '../../tools/unified-spec-runner/schema';
import { getEncryptExtraOptions } from '../../tools/utils';

Expand All @@ -22,7 +22,7 @@ describe('Client Side Encryption Functional', function () {
const keyVaultCollName = 'datakeys';
const keyVaultNamespace = `${keyVaultDbName}.${keyVaultCollName}`;

installNode18DNSHooks();
installNodeDNSWorkaroundHooks();

it('CSFLE_KMS_PROVIDERS should be valid EJSON', function () {
const CSFLE_KMS_PROVIDERS = process.env.CSFLE_KMS_PROVIDERS;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import { on } from 'events';
import { CommandStartedEvent } from '../../../src';
import { Collection } from '../../../src/collection';
import { MongoClient } from '../../../src/mongo_client';
import { installNode18DNSHooks } from '../../tools/runner/hooks/configuration';
import { HostAddress } from '../../../src/utils';
import { sleep } from '../../tools/utils';

const failPoint = {
Expand Down Expand Up @@ -45,13 +45,13 @@ describe('operationCount-based Selection Within Latency Window - Prose Test', fu
let seeds: Array<string>;
let counts: Record<string, number> = {};
const updateCount = ({ address }: CommandStartedEvent) => {
const mongosPort = address.split(':')[1];
const count = counts[mongosPort] ?? 0;
counts[mongosPort] = count + 1;
const hostAddress = HostAddress.fromString(address);
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
const port = hostAddress.port!.toString();
const count = counts[port] ?? 0;
counts[port] = count + 1;
};

installNode18DNSHooks();

beforeEach(async function () {
// Step 3: Create a client with both mongoses' addresses in its seed list, appName="loadBalancingTest", and localThresholdMS=30000.
const uri = this.configuration.url({
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const { MongoClient } = require('../../../src');
// TODO(NODE-3880): These tests are not fully implemented per the spec
describe('Atlas Data Lake - prose', function () {
let client;

beforeEach(function () {
client = null;
});
Expand All @@ -30,7 +31,8 @@ describe('Atlas Data Lake - prose', function () {
* If a driver constructs and issues killCursors commands in other ways (e.g. public API), this test MUST be adapted to test all such code paths.
*/
it('1. Test that the driver properly constructs and issues a killCursors command to Atlas Data Lake.', async function () {
client = new MongoClient('mongodb://mhuser:pencil@localhost');
// TODO(NODE-4884): once happy eyeballs support is added, we no longer need to set the default dns resolution order for CI
client = new MongoClient('mongodb://mhuser:pencil@localhost', { family: 4 });
const db = client.db('admin');
await db.command({ killCursors: 'kill_cursor_collection' });
});
Expand All @@ -39,7 +41,8 @@ describe('Atlas Data Lake - prose', function () {
* For these tests, create a MongoClient using a valid connection string without auth credentials and execute a ping command.
*/
it('2. Test that the driver can establish a connection with Atlas Data Lake without authentication.', async function () {
client = new MongoClient('mongodb://localhost');
// TODO(NODE-4884): once happy eyeballs support is added, we no longer need to set the default dns resolution order for CI
client = new MongoClient('mongodb://localhost', { family: 4 });
const db = client.db('admin');
await db.command({ ping: 1 });
});
Expand All @@ -49,7 +52,10 @@ describe('Atlas Data Lake - prose', function () {
* from the drivers-evergreen-tools ADL configuration and execute a ping command.
*/
it('3a. Test that the driver can establish a connection with Atlas Data Lake with authentication. (SCRAM-SHA-1)', async function () {
client = new MongoClient('mongodb://mhuser:pencil@localhost?authMechanism=SCRAM-SHA-1');
// TODO(NODE-4884): once happy eyeballs support is added, we no longer need to set the default dns resolution order for CI
client = new MongoClient('mongodb://mhuser:pencil@localhost?authMechanism=SCRAM-SHA-1', {
family: 4
});
const db = client.db('admin');
await db.command({ ping: 1 });
await db.command({ killCursors: 'kill_cursor_collection' });
Expand All @@ -59,7 +65,10 @@ describe('Atlas Data Lake - prose', function () {
* Repeat the authentication test using SCRAM-SHA-256.
*/
it('3b. Test that the driver can establish a connection with Atlas Data Lake with authentication. (SCRAM-SHA-256)', async function () {
client = new MongoClient('mongodb://mhuser:pencil@localhost?authMechanism=SCRAM-SHA-256');
// TODO(NODE-4884): once happy eyeballs support is added, we no longer need to set the default dns resolution order for CI
client = new MongoClient('mongodb://mhuser:pencil@localhost?authMechanism=SCRAM-SHA-256', {
family: 4
});
const db = client.db('admin');
await db.command({ ping: 1 });
await db.command({ killCursors: 'kill_cursor_collection' });
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
'use strict';
const path = require('path');
const { installNodeDNSWorkaroundHooks } = require('../../tools/runner/hooks/configuration');
const {
TestRunnerContext,
gatherTestSuites,
Expand All @@ -19,11 +20,19 @@ describe('Atlas Data Lake - spec', function () {
path.resolve(__dirname, '../../spec/atlas-data-lake-testing')
);

after(() => testContext.teardown());
// These tests timeout connecting to on localhost mongohoused in CI on Node18+.
// Manually setting the ip address resolution is safe for testing purposes
// because in production, mongohoused will never be running on localhost.
installNodeDNSWorkaroundHooks();

before(function () {
return testContext.setup(this.configuration);
});

after(() => {
testContext.teardown();
});

for (const suite of testSuites) suite.runOn = []; // patched in for the spec runner

generateTopologyTests(testSuites, testContext);
Expand Down
14 changes: 10 additions & 4 deletions test/manual/socks5.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import ConnectionString from 'mongodb-connection-string-url';
import { MongoClient } from '../../src';
import { LEGACY_HELLO_COMMAND } from '../../src/constants';
import { MongoParseError } from '../../src/error';
import { installNodeDNSWorkaroundHooks } from '../tools/runner/hooks/configuration';

/**
* The SOCKS5_CONFIG environment variable is either a JSON 4-tuple
Expand Down Expand Up @@ -34,6 +35,8 @@ describe('Socks5 Connectivity', function () {
rsConnectionString.searchParams.set('serverSelectionTimeoutMS', '2000');
singleConnectionString.searchParams.set('serverSelectionTimeoutMS', '2000');

installNodeDNSWorkaroundHooks();

context((proxyUsername ? 'with' : 'without') + ' Socks5 auth required', function () {
context('with missing required Socks5 auth configuration', function () {
if (!proxyUsername) {
Expand Down Expand Up @@ -302,9 +305,12 @@ async function testConnection(connectionString, clientOptions) {
let topologyType;
client.on('topologyDescriptionChanged', ev => (topologyType = ev.newDescription.type));

await client.connect();
await client.db('admin').command({ hello: 1 });
await client.db('test').collection('test').findOne({});
await client.close();
try {
await client.connect();
await client.db('admin').command({ hello: 1 });
await client.db('test').collection('test').findOne({});
} finally {
await client.close();
}
return topologyType;
}
Loading

0 comments on commit 4c49b2e

Please sign in to comment.