Skip to content

Commit

Permalink
initial implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
baileympearson committed Nov 11, 2024
1 parent db4eff5 commit b527e5b
Show file tree
Hide file tree
Showing 14 changed files with 1,109 additions and 249 deletions.
19 changes: 18 additions & 1 deletion src/cmap/connect.ts
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,8 @@ export async function performInitialHandshake(
}

const start = new Date().getTime();
const response = await conn.command(ns('admin.$cmd'), handshakeDoc, handshakeOptions);

const response = await executeHandshake(handshakeDoc, handshakeOptions);

if (!('isWritablePrimary' in response)) {
// Provide hello-style response document.
Expand Down Expand Up @@ -175,6 +176,22 @@ export async function performInitialHandshake(
// Connection establishment is socket creation (tcp handshake, tls handshake, MongoDB handshake (saslStart, saslContinue))
// Once connection is established, command logging can log events (if enabled)
conn.established = true;

async function executeHandshake(handshakeDoc: Document, handshakeOptions: CommandOptions) {
try {
const handshakeResponse = await conn.command(
ns('admin.$cmd'),
handshakeDoc,
handshakeOptions
);
return handshakeResponse;
} catch (error) {
if (error instanceof MongoError) {
error.addErrorLabel(MongoErrorLabel.HandshakeError);
}
throw error;
}
}
}

/**
Expand Down
4 changes: 1 addition & 3 deletions src/cmap/connection_pool.ts
Original file line number Diff line number Diff line change
Expand Up @@ -685,6 +685,7 @@ export class ConnectionPool extends TypedEventEmitter<ConnectionPoolEvents> {
},
error => {
this[kPending]--;
this[kServer].handleError(error);
this.emitAndLog(
ConnectionPool.CONNECTION_CLOSED,
new ConnectionClosedEvent(
Expand Down Expand Up @@ -719,9 +720,6 @@ export class ConnectionPool extends TypedEventEmitter<ConnectionPoolEvents> {
// connection permits because that potentially delays the availability of
// the connection to a checkout request
this.createConnection((err, connection) => {
if (err) {
this[kServer].handleError(err);
}
if (!err && connection) {
this[kConnections].push(connection);
process.nextTick(() => this.processWaitQueue());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -69,9 +69,6 @@ describe('Connection Monitoring and Pooling Spec Tests (Integration) - logging',
) {
return 'not applicable: waitQueueSize not supported';
}
if (test.description === 'Connection checkout fails due to error establishing connection') {
return 'TODO(NODE-5230): unskip this once event ordering issue is resolved';
}
return false;
});
});
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { loadSpecTests } from '../../spec';
import { type CmapTest, runCmapTestSuite } from '../../tools/cmap_spec_runner';
import { runUnifiedSuite } from '../../tools/unified-spec-runner/runner';

describe('Connection Monitoring and Pooling (Node Driver)', function () {
const cmapTests: CmapTest[] = loadSpecTests(
Expand All @@ -17,10 +16,4 @@ describe('Connection Monitoring and Pooling (Node Driver)', function () {
}
]
});

// TODO(NODE-5230): Remove this once the actual unified tests (test/spec/connection-monitoring-and-pooling/logging) are passing
const unifiedTests = loadSpecTests(
'../integration/connection-monitoring-and-pooling/unified-cmap-node-specs'
);
runUnifiedSuite(unifiedTests);
});

This file was deleted.

Original file line number Diff line number Diff line change
Expand Up @@ -49,15 +49,15 @@
"type": "ConnectionCreated",
"address": 42
},
{
"type": "ConnectionPoolCleared",
"address": 42
},
{
"type": "ConnectionClosed",
"address": 42,
"connectionId": 42,
"reason": "error"
},
{
"type": "ConnectionPoolCleared",
"address": 42
}
],
"ignore": [
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,11 +30,11 @@ events:
address: 42
- type: ConnectionCreated
address: 42
- type: ConnectionPoolCleared
address: 42
- type: ConnectionClosed
address: 42
connectionId: 42
reason: error
- type: ConnectionPoolCleared
address: 42
ignore:
- ConnectionPoolCreated
Loading

0 comments on commit b527e5b

Please sign in to comment.