Skip to content

Commit

Permalink
feat: Enable leader aware routing by default (#1851)
Browse files Browse the repository at this point in the history
  • Loading branch information
surbhigarg92 authored Jul 21, 2023
1 parent 5e407c0 commit 87cd5e6
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 14 deletions.
10 changes: 5 additions & 5 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -108,8 +108,8 @@ export type GetInstanceConfigOperationsCallback = PagedCallback<

/**
* Session pool configuration options.
* @property {boolean} [routeToLeaderEnabled=False] If set to true leader aware routing will be enabled.
* Enabling leader aware routing would route all requests in RW/PDML transactions to leader region.
* @property {boolean} [routeToLeaderEnabled=True] If set to false leader aware routing will be disabled.
* Disabling leader aware routing would route all requests in RW/PDML transactions to any region.
*/
export interface SpannerOptions extends GrpcClientOptions {
apiEndpoint?: string;
Expand Down Expand Up @@ -216,7 +216,7 @@ class Spanner extends GrpcService {
projectIdReplaced_: boolean;
projectFormattedName_: string;
resourceHeader_: {[k: string]: string};
routeToLeaderEnabled = false;
routeToLeaderEnabled = true;

/**
* Placeholder used to auto populate a column with the commit timestamp.
Expand Down Expand Up @@ -318,8 +318,8 @@ class Spanner extends GrpcService {
} as {} as GrpcServiceConfig;
super(config, options);

if (options.routeToLeaderEnabled === true) {
this.routeToLeaderEnabled = true;
if (options.routeToLeaderEnabled === false) {
this.routeToLeaderEnabled = false;
}

this.options = options;
Expand Down
18 changes: 9 additions & 9 deletions test/spanner.ts
Original file line number Diff line number Diff line change
Expand Up @@ -1491,33 +1491,33 @@ describe('Spanner with mock server', () => {
});

describe('LeaderAwareRouting', () => {
let spannerWithLAREnabled: Spanner;
let instanceWithLAREnabled: Instance;
let spannerWithLARDisabled: Spanner;
let instanceWithLARDisabled: Instance;

function newTestDatabaseWithLAREnabled(
function newTestDatabaseWithLARDisabled(
options?: SessionPoolOptions,
queryOptions?: IQueryOptions
): Database {
return instanceWithLAREnabled.database(
return instanceWithLARDisabled.database(
`database-${dbCounter++}`,
options,
queryOptions
);
}

before(() => {
spannerWithLAREnabled = new Spanner({
spannerWithLARDisabled = new Spanner({
servicePath: 'localhost',
port,
sslCreds: grpc.credentials.createInsecure(),
routeToLeaderEnabled: true,
routeToLeaderEnabled: false,
});
// Gets a reference to a Cloud Spanner instance and database
instanceWithLAREnabled = spannerWithLAREnabled.instance('instance');
instanceWithLARDisabled = spannerWithLARDisabled.instance('instance');
});

it('should execute with leader aware routing enabled in a read/write transaction', async () => {
const database = newTestDatabaseWithLAREnabled();
const database = newTestDatabase();
await database.runTransactionAsync(async tx => {
await tx!.runUpdate({
sql: insertSql,
Expand All @@ -1539,7 +1539,7 @@ describe('Spanner with mock server', () => {
});

it('should execute with leader aware routing disabled in a read/write transaction', async () => {
const database = newTestDatabase();
const database = newTestDatabaseWithLARDisabled();
await database.runTransactionAsync(async tx => {
await tx!.runUpdate({
sql: insertSql,
Expand Down

0 comments on commit 87cd5e6

Please sign in to comment.