n8n/packages/nodes-base/nodes/Snowflake/__tests__/GenericFunctions.test.ts
n8n-assistant[bot] aec110f198
Some checks are pending
CI: Master (Build, Test, Lint) / Build for Github Cache (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (22.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (24.13.1) (push) Waiting to run
CI: Master (Build, Test, Lint) / Unit tests (25.x) (push) Waiting to run
CI: Master (Build, Test, Lint) / Lint (push) Waiting to run
CI: Master (Build, Test, Lint) / Performance (push) Waiting to run
CI: Master (Build, Test, Lint) / Notify Slack on failure (push) Blocked by required conditions
fix(Snowflake Node): Fix issue with Insert and Update operations not working (backport to 1.x) (#29812)
Co-authored-by: Jon <jonathan.bennetts@gmail.com>
Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-05-06 16:03:40 +00:00

103 lines
2.7 KiB
TypeScript

import crypto from 'crypto';
import { escapeSnowflakeObjectIdentifier, getConnectionOptions } from '../GenericFunctions';
jest.mock('crypto');
describe('escapeSnowflakeObjectIdentifier', () => {
it('quotes a single-part identifier', () => {
expect(escapeSnowflakeObjectIdentifier('orders')).toBe('"ORDERS"');
});
it('quotes each segment of a two-part identifier', () => {
expect(escapeSnowflakeObjectIdentifier('schema.orders')).toBe('"SCHEMA"."ORDERS"');
});
it('quotes each segment of a three-part identifier', () => {
expect(escapeSnowflakeObjectIdentifier('db.schema.orders')).toBe('"DB"."SCHEMA"."ORDERS"');
});
it('preserves case for pre-quoted identifiers', () => {
expect(escapeSnowflakeObjectIdentifier('"myTable"')).toBe('"myTable"');
});
it('does not split on dots inside quoted segments', () => {
expect(escapeSnowflakeObjectIdentifier('"my.schema"."my.table"')).toBe(
'"my.schema"."my.table"',
);
});
});
describe('getConnectionOptions', () => {
const commonOptions = {
account: 'test-account',
database: 'test-database',
schema: 'test-schema',
warehouse: 'test-warehouse',
role: 'test-role',
clientSessionKeepAlive: true,
};
describe('should return connection options', () => {
it('with username and password for password authentication', () => {
const result = getConnectionOptions({
...commonOptions,
authentication: 'password',
username: 'test-username',
password: 'test-password',
});
expect(result).toEqual({
...commonOptions,
username: 'test-username',
password: 'test-password',
});
});
it('with private key for keyPair authentication', () => {
const result = getConnectionOptions({
...commonOptions,
username: 'test-username',
authentication: 'keyPair',
privateKey: 'test-private-key',
});
expect(result).toEqual({
...commonOptions,
username: 'test-username',
authenticator: 'SNOWFLAKE_JWT',
privateKey: 'test-private-key',
});
});
it('with private key for keyPair authentication and passphrase', () => {
const createPrivateKeySpy = jest.spyOn(crypto, 'createPrivateKey').mockImplementation(
() =>
({
export: () => 'test-private-key',
}) as unknown as crypto.KeyObject,
);
const result = getConnectionOptions({
...commonOptions,
username: 'test-username',
authentication: 'keyPair',
privateKey: 'encrypted-private-key',
passphrase: 'test-passphrase',
});
expect(createPrivateKeySpy).toHaveBeenCalledWith({
key: 'encrypted-private-key',
format: 'pem',
passphrase: 'test-passphrase',
});
expect(result).toEqual({
...commonOptions,
username: 'test-username',
authenticator: 'SNOWFLAKE_JWT',
privateKey: 'test-private-key',
});
});
});
});