-
Notifications
You must be signed in to change notification settings - Fork 6.6k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
fix(Google Sheets Node): Insert data if sheet is empty instead of err…
…or (#10942)
- Loading branch information
1 parent
ad60d49
commit c75990e
Showing
5 changed files
with
178 additions
and
6 deletions.
There are no files selected for viewing
59 changes: 59 additions & 0 deletions
59
packages/nodes-base/nodes/Google/Sheet/test/v2/node/append.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
import type { MockProxy } from 'jest-mock-extended'; | ||
import { mock } from 'jest-mock-extended'; | ||
import type { IExecuteFunctions, INode } from 'n8n-workflow'; | ||
|
||
import { execute } from '../../../v2/actions/sheet/append.operation'; | ||
import type { GoogleSheet } from '../../../v2/helpers/GoogleSheet'; | ||
|
||
describe('Google Sheet - Append', () => { | ||
let mockExecuteFunctions: MockProxy<IExecuteFunctions>; | ||
let mockGoogleSheet: MockProxy<GoogleSheet>; | ||
|
||
beforeEach(() => { | ||
mockExecuteFunctions = mock<IExecuteFunctions>(); | ||
mockGoogleSheet = mock<GoogleSheet>(); | ||
}); | ||
|
||
it('should insert input data if sheet is empty', async () => { | ||
mockExecuteFunctions.getInputData.mockReturnValueOnce([ | ||
{ | ||
json: { | ||
row_number: 3, | ||
name: 'NEW NAME', | ||
text: 'NEW TEXT', | ||
}, | ||
pairedItem: { | ||
item: 0, | ||
input: undefined, | ||
}, | ||
}, | ||
]); | ||
|
||
mockExecuteFunctions.getNode.mockReturnValueOnce(mock<INode>({ typeVersion: 4.5 })); | ||
mockExecuteFunctions.getNodeParameter | ||
.mockReturnValueOnce('USER_ENTERED') // valueInputMode | ||
.mockReturnValueOnce({}); // options | ||
mockExecuteFunctions.getNodeParameter.mockReturnValueOnce('defineBelow'); // dataMode | ||
|
||
mockGoogleSheet.getData.mockResolvedValueOnce(undefined); | ||
mockGoogleSheet.getData.mockResolvedValueOnce(undefined); | ||
mockGoogleSheet.updateRows.mockResolvedValueOnce(undefined); | ||
|
||
mockGoogleSheet.updateRows.mockResolvedValueOnce([]); | ||
|
||
mockGoogleSheet.appendEmptyRowsOrColumns.mockResolvedValueOnce([]); | ||
mockGoogleSheet.appendSheetData.mockResolvedValueOnce([]); | ||
|
||
await execute.call(mockExecuteFunctions, mockGoogleSheet, 'Sheet1', '1234'); | ||
|
||
expect(mockGoogleSheet.updateRows).toHaveBeenCalledWith('Sheet1', [['name', 'text']], 'RAW', 1); | ||
expect(mockGoogleSheet.appendEmptyRowsOrColumns).toHaveBeenCalledWith('1234', 1, 0); | ||
expect(mockGoogleSheet.appendSheetData).toHaveBeenCalledWith({ | ||
inputData: [{ name: 'NEW NAME', text: 'NEW TEXT' }], | ||
keyRowIndex: 1, | ||
lastRow: 2, | ||
range: 'Sheet1', | ||
valueInputMode: 'USER_ENTERED', | ||
}); | ||
}); | ||
}); |
98 changes: 98 additions & 0 deletions
98
packages/nodes-base/nodes/Google/Sheet/test/v2/node/appendOrUpdate.test.ts
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,98 @@ | ||
import type { MockProxy } from 'jest-mock-extended'; | ||
import { mock } from 'jest-mock-extended'; | ||
import type { IExecuteFunctions, INode } from 'n8n-workflow'; | ||
|
||
import { execute } from '../../../v2/actions/sheet/appendOrUpdate.operation'; | ||
import type { GoogleSheet } from '../../../v2/helpers/GoogleSheet'; | ||
|
||
describe('Google Sheet - Append or Update', () => { | ||
let mockExecuteFunctions: MockProxy<IExecuteFunctions>; | ||
let mockGoogleSheet: MockProxy<GoogleSheet>; | ||
|
||
beforeEach(() => { | ||
mockExecuteFunctions = mock<IExecuteFunctions>(); | ||
mockGoogleSheet = mock<GoogleSheet>(); | ||
}); | ||
|
||
it('should insert input data if sheet is empty', async () => { | ||
mockExecuteFunctions.getInputData.mockReturnValueOnce([ | ||
{ | ||
json: { | ||
row_number: 3, | ||
name: 'NEW NAME', | ||
text: 'NEW TEXT', | ||
}, | ||
pairedItem: { | ||
item: 0, | ||
input: undefined, | ||
}, | ||
}, | ||
]); | ||
|
||
mockExecuteFunctions.getNode.mockReturnValueOnce(mock<INode>({ typeVersion: 4.5 })); | ||
mockExecuteFunctions.getNodeParameter | ||
.mockReturnValueOnce('USER_ENTERED') // valueInputMode | ||
.mockReturnValueOnce({}); // options | ||
mockExecuteFunctions.getNodeParameter.mockReturnValueOnce('defineBelow'); // dataMode | ||
mockExecuteFunctions.getNodeParameter.mockReturnValueOnce([]); // columns.schema | ||
mockExecuteFunctions.getNodeParameter.mockReturnValueOnce(['row_number']); // columnsToMatchOn | ||
mockExecuteFunctions.getNode.mockReturnValueOnce(mock<INode>()); | ||
mockExecuteFunctions.getNodeParameter.mockReturnValueOnce([]); // columns.matchingColumns | ||
|
||
mockGoogleSheet.getData.mockResolvedValueOnce(undefined); | ||
|
||
mockGoogleSheet.getColumnValues.mockResolvedValueOnce([]); | ||
mockGoogleSheet.updateRows.mockResolvedValueOnce([]); | ||
|
||
mockGoogleSheet.prepareDataForUpdateOrUpsert.mockResolvedValueOnce({ | ||
updateData: [], | ||
appendData: [ | ||
{ | ||
row_number: 3, | ||
name: 'NEW NAME', | ||
text: 'NEW TEXT', | ||
}, | ||
], | ||
}); | ||
|
||
mockGoogleSheet.appendEmptyRowsOrColumns.mockResolvedValueOnce([]); | ||
mockGoogleSheet.appendSheetData.mockResolvedValueOnce([]); | ||
|
||
await execute.call(mockExecuteFunctions, mockGoogleSheet, 'Sheet1', '1234'); | ||
|
||
expect(mockGoogleSheet.getColumnValues).toHaveBeenCalledWith({ | ||
dataStartRowIndex: 1, | ||
keyIndex: -1, | ||
range: 'Sheet1!A:Z', | ||
sheetData: [['name', 'text']], | ||
valueRenderMode: 'UNFORMATTED_VALUE', | ||
}); | ||
|
||
expect(mockGoogleSheet.updateRows).toHaveBeenCalledWith( | ||
'Sheet1', | ||
[['name', 'text']], | ||
'USER_ENTERED', | ||
1, | ||
); | ||
expect(mockGoogleSheet.prepareDataForUpdateOrUpsert).toHaveBeenCalledWith({ | ||
columnNamesList: [['name', 'text']], | ||
columnValuesList: [], | ||
dataStartRowIndex: 1, | ||
indexKey: 'row_number', | ||
inputData: [{ name: 'NEW NAME', row_number: 3, text: 'NEW TEXT' }], | ||
keyRowIndex: 0, | ||
range: 'Sheet1!A:Z', | ||
upsert: true, | ||
valueRenderMode: 'UNFORMATTED_VALUE', | ||
}); | ||
expect(mockGoogleSheet.appendEmptyRowsOrColumns).toHaveBeenCalledWith('1234', 1, 0); | ||
expect(mockGoogleSheet.appendSheetData).toHaveBeenCalledWith({ | ||
columnNamesList: [['name', 'text']], | ||
inputData: [{ name: 'NEW NAME', row_number: 3, text: 'NEW TEXT' }], | ||
keyRowIndex: 1, | ||
lastRow: 2, | ||
range: 'Sheet1!A:Z', | ||
valueInputMode: 'USER_ENTERED', | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters