fix(Google Sheets Trigger Node): Fix issue with regex showing correct sheet as invalid (#11770)

This commit is contained in:
Jon 2024-11-18 11:54:20 +00:00 committed by GitHub
parent 124ac26e43
commit d5ba1a059b
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 89 additions and 11 deletions

View file

@ -7,7 +7,7 @@ import type {
} from 'n8n-workflow'; } from 'n8n-workflow';
import { NodeConnectionType, NodeOperationError } from 'n8n-workflow'; import { NodeConnectionType, NodeOperationError } from 'n8n-workflow';
import { GOOGLE_DRIVE_FILE_URL_REGEX } from '../constants'; import { GOOGLE_DRIVE_FILE_URL_REGEX, GOOGLE_SHEETS_SHEET_URL_REGEX } from '../constants';
import { apiRequest } from './v2/transport'; import { apiRequest } from './v2/transport';
import { sheetsSearch, spreadSheetsSearch } from './v2/methods/listSearch'; import { sheetsSearch, spreadSheetsSearch } from './v2/methods/listSearch';
import { GoogleSheet } from './v2/helpers/GoogleSheet'; import { GoogleSheet } from './v2/helpers/GoogleSheet';
@ -137,15 +137,13 @@ export class GoogleSheetsTrigger implements INodeType {
type: 'string', type: 'string',
extractValue: { extractValue: {
type: 'regex', type: 'regex',
regex: regex: GOOGLE_SHEETS_SHEET_URL_REGEX,
'https:\\/\\/docs\\.google\\.com/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+\\/edit\\#gid=([0-9]+)',
}, },
validation: [ validation: [
{ {
type: 'regex', type: 'regex',
properties: { properties: {
regex: regex: GOOGLE_SHEETS_SHEET_URL_REGEX,
'https:\\/\\/docs\\.google\\.com/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+\\/edit\\#gid=([0-9]+)',
errorMessage: 'Not a valid Sheet URL', errorMessage: 'Not a valid Sheet URL',
}, },
}, },

View file

@ -1,9 +1,16 @@
import type { IExecuteFunctions, INode, ResourceMapperField } from 'n8n-workflow'; import {
NodeOperationError,
type IExecuteFunctions,
type INode,
type ResourceMapperField,
} from 'n8n-workflow';
import { GoogleSheet } from '../../../v2/helpers/GoogleSheet'; import { GoogleSheet } from '../../../v2/helpers/GoogleSheet';
import { import {
addRowNumber, addRowNumber,
autoMapInputData, autoMapInputData,
checkForSchemaChanges, checkForSchemaChanges,
getSpreadsheetId,
prepareSheetData, prepareSheetData,
removeEmptyColumns, removeEmptyColumns,
removeEmptyRows, removeEmptyRows,
@ -11,6 +18,8 @@ import {
trimToFirstEmptyRow, trimToFirstEmptyRow,
} from '../../../v2/helpers/GoogleSheets.utils'; } from '../../../v2/helpers/GoogleSheets.utils';
import { GOOGLE_SHEETS_SHEET_URL_REGEX } from '../../../../constants';
describe('Test Google Sheets, addRowNumber', () => { describe('Test Google Sheets, addRowNumber', () => {
it('should add row nomber', () => { it('should add row nomber', () => {
const data = [ const data = [
@ -444,3 +453,73 @@ describe('Test Google Sheets, checkForSchemaChanges', () => {
).toThrow("Column names were updated after the node's setup"); ).toThrow("Column names were updated after the node's setup");
}); });
}); });
describe('Test Google Sheets, getSpreadsheetId', () => {
let mockNode: INode;
beforeEach(() => {
mockNode = { name: 'Google Sheets' } as INode;
jest.clearAllMocks();
});
it('should throw an error if value is empty', () => {
expect(() => getSpreadsheetId(mockNode, 'url', '')).toThrow(NodeOperationError);
});
it('should return the ID from a valid URL', () => {
const url =
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit#gid=0';
const result = getSpreadsheetId(mockNode, 'url', url);
expect(result).toBe('1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms');
});
it('should return an empty string for an invalid URL', () => {
const url = 'https://docs.google.com/spreadsheets/d/';
const result = getSpreadsheetId(mockNode, 'url', url);
expect(result).toBe('');
});
it('should return the value for documentIdType byId or byList', () => {
const value = '1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms';
expect(getSpreadsheetId(mockNode, 'id', value)).toBe(value);
expect(getSpreadsheetId(mockNode, 'list', value)).toBe(value);
});
});
describe('Test Google Sheets, Google Sheets Sheet URL Regex', () => {
const regex = new RegExp(GOOGLE_SHEETS_SHEET_URL_REGEX);
it('should match a valid Google Sheets URL', () => {
const urls = [
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit#gid=0',
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit#gid=123456',
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit?gid=654321#gid=654321',
];
for (const url of urls) {
expect(regex.test(url)).toBe(true);
}
});
it('should not match an invalid Google Sheets URL', () => {
const url = 'https://docs.google.com/spreadsheets/d/';
expect(regex.test(url)).toBe(false);
});
it('should not match a URL that does not match the pattern', () => {
const url =
'https://example.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit#gid=0';
expect(regex.test(url)).toBe(false);
});
it('should extract the gid from a valid Google Sheets URL', () => {
const urls = [
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit#gid=12345',
'https://docs.google.com/spreadsheets/d/1BxiMVs0XRA5nFMdKvBdBZjgmUUqptlbs74OgvE2upms/edit?gid=12345#gid=12345',
];
for (const url of urls) {
const match = url.match(regex);
expect(match).not.toBeNull();
expect(match?.[1]).toBe('12345');
}
});
});

View file

@ -1,5 +1,5 @@
import type { INodeProperties } from 'n8n-workflow'; import type { INodeProperties } from 'n8n-workflow';
import { GOOGLE_DRIVE_FILE_URL_REGEX } from '../../../../constants'; import { GOOGLE_DRIVE_FILE_URL_REGEX, GOOGLE_SHEETS_SHEET_URL_REGEX } from '../../../../constants';
import * as append from './append.operation'; import * as append from './append.operation';
import * as appendOrUpdate from './appendOrUpdate.operation'; import * as appendOrUpdate from './appendOrUpdate.operation';
import * as clear from './clear.operation'; import * as clear from './clear.operation';
@ -156,15 +156,13 @@ export const descriptions: INodeProperties[] = [
type: 'string', type: 'string',
extractValue: { extractValue: {
type: 'regex', type: 'regex',
regex: regex: GOOGLE_SHEETS_SHEET_URL_REGEX,
'https:\\/\\/docs\\.google.com\\/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+.*\\#gid=([0-9]+)',
}, },
validation: [ validation: [
{ {
type: 'regex', type: 'regex',
properties: { properties: {
regex: regex: GOOGLE_SHEETS_SHEET_URL_REGEX,
'https:\\/\\/docs\\.google.com\\/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+.*\\#gid=([0-9]+)',
errorMessage: 'Not a valid Sheet URL', errorMessage: 'Not a valid Sheet URL',
}, },
}, },

View file

@ -3,3 +3,6 @@ export const GOOGLE_DRIVE_FILE_URL_REGEX =
export const GOOGLE_DRIVE_FOLDER_URL_REGEX = export const GOOGLE_DRIVE_FOLDER_URL_REGEX =
'https:\\/\\/drive\\.google\\.com(?:\\/.*|)\\/folders\\/([0-9a-zA-Z\\-_]+)(?:\\/.*|)'; 'https:\\/\\/drive\\.google\\.com(?:\\/.*|)\\/folders\\/([0-9a-zA-Z\\-_]+)(?:\\/.*|)';
export const GOOGLE_SHEETS_SHEET_URL_REGEX =
'https:\\/\\/docs\\.google\\.com\\/spreadsheets\\/d\\/[0-9a-zA-Z\\-_]+.*\\#gid=([0-9]+)';