Skip to content

Commit

Permalink
observability-test: isolate ObservabilityOptions injection tests
Browse files Browse the repository at this point in the history
  • Loading branch information
odeke-em committed Oct 4, 2024
1 parent b69e3b9 commit 3d6aaf2
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 51 deletions.
114 changes: 70 additions & 44 deletions observability-test/spanner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -206,6 +206,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.getSnapshot',
];
Expand Down Expand Up @@ -249,6 +250,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.getTransaction',
];
Expand Down Expand Up @@ -293,6 +295,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.runStream',
];
Expand Down Expand Up @@ -339,6 +342,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.runStream',
'CloudSpanner.Database.run',
Expand Down Expand Up @@ -401,6 +405,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.runTransaction',
];
Expand Down Expand Up @@ -445,6 +450,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.writeAtLeastOnce',
];
Expand Down Expand Up @@ -488,6 +494,7 @@ describe('EndToEnd', () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.batchCreateSessions',
];
Expand Down Expand Up @@ -515,46 +522,32 @@ describe('EndToEnd', () => {
});

describe('ObservabilityOptions injection and propagation', async () => {
const globalTraceExporter = new InMemorySpanExporter();
const globalTracerProvider = new NodeTracerProvider({
sampler: new AlwaysOnSampler(),
exporter: globalTraceExporter,
});
globalTracerProvider.addSpanProcessor(
new SimpleSpanProcessor(globalTraceExporter)
);
globalTracerProvider.register();

const injectedTraceExporter = new InMemorySpanExporter();
const injectedTracerProvider = new NodeTracerProvider({
sampler: new AlwaysOnSampler(),
exporter: injectedTraceExporter,
});
injectedTracerProvider.addSpanProcessor(
new SimpleSpanProcessor(injectedTraceExporter)
);

const observabilityOptions: typeof ObservabilityOptions = {
tracerProvider: injectedTracerProvider,
enableExtendedTracing: true,
};

const setupResult = await setup(observabilityOptions);
const spanner = setupResult.spanner;
const server = setupResult.server;
const spannerMock = setupResult.spannerMock;

after(async () => {
globalTraceExporter.reset();
injectedTraceExporter.reset();
await globalTracerProvider.shutdown();
await injectedTracerProvider.shutdown();
spannerMock.resetRequests();
spanner.close();
server.tryShutdown(() => {});
});
it('Passed into Spanner, Instance and Database', async () => {
const traceExporter = new InMemorySpanExporter();
const tracerProvider = new NodeTracerProvider({
sampler: new AlwaysOnSampler(),
exporter: traceExporter,
});
tracerProvider.addSpanProcessor(new SimpleSpanProcessor(traceExporter));

const observabilityOptions: typeof ObservabilityOptions = {
tracerProvider: tracerProvider,
enableExtendedTracing: true,
};

const setupResult = await setup(observabilityOptions);
const spanner = setupResult.spanner;
const server = setupResult.server;
const spannerMock = setupResult.spannerMock;

after(async () => {
traceExporter.reset();
await tracerProvider.shutdown();
spannerMock.resetRequests();
spanner.close();
server.tryShutdown(() => {});
});

it('Passed into Spanner, Instance and Database', done => {
// Ensure that the same observability configuration is set on the Spanner client.
assert.deepStrictEqual(spanner._observabilityOptions, observabilityOptions);

Expand Down Expand Up @@ -588,11 +581,45 @@ describe('ObservabilityOptions injection and propagation', async () => {
databaseByConstructor._observabilityOptions,
observabilityOptions
);

done();
});

it('Propagates spans to the injected not global TracerProvider', done => {
it('Propagates spans to the injected not global TracerProvider', async () => {
const globalTraceExporter = new InMemorySpanExporter();
const globalTracerProvider = new NodeTracerProvider({
sampler: new AlwaysOnSampler(),
exporter: globalTraceExporter,
});
globalTracerProvider.addSpanProcessor(
new SimpleSpanProcessor(globalTraceExporter)
);
globalTracerProvider.register();

const injectedTraceExporter = new InMemorySpanExporter();
const injectedTracerProvider = new NodeTracerProvider({
sampler: new AlwaysOnSampler(),
exporter: injectedTraceExporter,
});
injectedTracerProvider.addSpanProcessor(
new SimpleSpanProcessor(injectedTraceExporter)
);

const observabilityOptions: typeof ObservabilityOptions = {
tracerProvider: injectedTracerProvider,
enableExtendedTracing: true,
};
const setupResult = await setup(observabilityOptions);
const spanner = setupResult.spanner;
const server = setupResult.server;
const spannerMock = setupResult.spannerMock;

after(async () => {
injectedTraceExporter.reset();
await injectedTracerProvider.shutdown();
spannerMock.resetRequests();
spanner.close();
server.tryShutdown(() => {});
});

const instance = spanner.instance('instance');
const database = instance.database('database');

Expand Down Expand Up @@ -628,6 +655,7 @@ describe('ObservabilityOptions injection and propagation', async () => {
});

const expectedSpanNames = [
'CloudSpanner.Database.batchCreateSessions',
'CloudSpanner.SessionPool.createSessions',
'CloudSpanner.Database.runStream',
'CloudSpanner.Database.run',
Expand All @@ -652,8 +680,6 @@ describe('ObservabilityOptions injection and propagation', async () => {
expectedEventNames,
`Unexpected events:\n\tGot: ${actualEventNames}\n\tWant: ${expectedEventNames}`
);

done();
});
});
});
9 changes: 5 additions & 4 deletions src/database.ts
Original file line number Diff line number Diff line change
Expand Up @@ -450,14 +450,14 @@ class Database extends common.GrpcServiceObject {
typeof poolOptions === 'function'
? new (poolOptions as SessionPoolConstructor)(this, null)
: new SessionPool(this, poolOptions);
const concretePool = this.pool_ as SessionPool;
if (concretePool) {
concretePool._observabilityOptions = instance._observabilityOptions;
const sessionPoolInstance = this.pool_ as SessionPool;
if (sessionPoolInstance) {
sessionPoolInstance._observabilityOptions =
instance._observabilityOptions;
}
if (typeof poolOptions === 'object') {
this.databaseRole = poolOptions.databaseRole || null;
}
this._observabilityOptions = instance._observabilityOptions;
this.formattedName_ = formattedName_;
this.instance = instance;
this.resourceHeader_ = {
Expand All @@ -472,6 +472,7 @@ class Database extends common.GrpcServiceObject {
Object.assign({}, queryOptions),
Database.getEnvironmentQueryOptions()
);
this._observabilityOptions = instance._observabilityOptions;
}
/**
* @typedef {array} SetDatabaseMetadataResponse
Expand Down
4 changes: 1 addition & 3 deletions src/instance.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1361,9 +1361,7 @@ class Instance extends common.GrpcServiceObject {
let databases: Database[] | null = null;
if (rowDatabases) {
databases = rowDatabases.map(database => {
const databaseInstance = self.database(database.name!, {
min: 0,
});
const databaseInstance = self.database(database.name!, {min: 0});
databaseInstance.metadata = database;
databaseInstance._observabilityOptions = this._observabilityOptions;
return databaseInstance;
Expand Down

0 comments on commit 3d6aaf2

Please sign in to comment.