feat(core): Introduce simplified node versioning (#3205)
* ✨ Introduce simple node versioning * ⚡ Add example how to read version in node-code for custom logic * 🐛 Fix setting of parameters * 🐛 Fix another instance where it sets the wrong parameter * ⚡ Remove unnecessary TOODs * ⚡ Revert Set Node example changes * ;rotating_light: Add test
This commit is contained in:
@@ -517,6 +517,65 @@ class NodeTypesClass implements INodeTypes {
|
||||
},
|
||||
},
|
||||
},
|
||||
'n8n-nodes-base.versionTest': {
|
||||
sourcePath: '',
|
||||
type: {
|
||||
description: {
|
||||
displayName: 'Version Test',
|
||||
name: 'versionTest',
|
||||
group: ['input'],
|
||||
version: 1,
|
||||
description: 'Tests if versioning works',
|
||||
defaults: {
|
||||
name: 'Version Test',
|
||||
color: '#0000FF',
|
||||
},
|
||||
inputs: ['main'],
|
||||
outputs: ['main'],
|
||||
properties: [
|
||||
{
|
||||
displayName: 'Display V1',
|
||||
name: 'versionTest',
|
||||
type: 'number',
|
||||
displayOptions: {
|
||||
show: {
|
||||
'@version': [1],
|
||||
},
|
||||
},
|
||||
default: 1,
|
||||
},
|
||||
{
|
||||
displayName: 'Display V2',
|
||||
name: 'versionTest',
|
||||
type: 'number',
|
||||
displayOptions: {
|
||||
show: {
|
||||
'@version': [2],
|
||||
},
|
||||
},
|
||||
default: 2,
|
||||
},
|
||||
],
|
||||
},
|
||||
execute(this: IExecuteFunctions): Promise<INodeExecutionData[][]> {
|
||||
const items = this.getInputData();
|
||||
const returnData: INodeExecutionData[] = [];
|
||||
|
||||
for (let itemIndex = 0; itemIndex < items.length; itemIndex++) {
|
||||
const newItem: INodeExecutionData = {
|
||||
json: {
|
||||
versionFromParameter: this.getNodeParameter('versionTest', itemIndex),
|
||||
versionFromNode: this.getNode().typeVersion,
|
||||
},
|
||||
};
|
||||
|
||||
returnData.push(newItem);
|
||||
}
|
||||
|
||||
return this.prepareOutputData(returnData);
|
||||
},
|
||||
},
|
||||
},
|
||||
'n8n-nodes-base.set': {
|
||||
sourcePath: '',
|
||||
type: {
|
||||
|
||||
@@ -1169,6 +1169,145 @@ describe('WorkflowExecute', () => {
|
||||
},
|
||||
},
|
||||
},
|
||||
|
||||
{
|
||||
description:
|
||||
'should display the correct parameters and so correct data when simplified node-versioning is used',
|
||||
input: {
|
||||
workflowData: {
|
||||
nodes: [
|
||||
{
|
||||
parameters: {},
|
||||
name: 'Start',
|
||||
type: 'n8n-nodes-base.start',
|
||||
typeVersion: 1,
|
||||
position: [240, 300],
|
||||
},
|
||||
{
|
||||
parameters: {},
|
||||
name: 'VersionTest1a',
|
||||
type: 'n8n-nodes-base.versionTest',
|
||||
typeVersion: 1,
|
||||
position: [460, 300],
|
||||
},
|
||||
{
|
||||
parameters: {
|
||||
versionTest: 11,
|
||||
},
|
||||
name: 'VersionTest1b',
|
||||
type: 'n8n-nodes-base.versionTest',
|
||||
typeVersion: 1,
|
||||
position: [680, 300],
|
||||
},
|
||||
{
|
||||
parameters: {},
|
||||
name: 'VersionTest2a',
|
||||
type: 'n8n-nodes-base.versionTest',
|
||||
typeVersion: 2,
|
||||
position: [880, 300],
|
||||
},
|
||||
{
|
||||
parameters: {
|
||||
versionTest: 22,
|
||||
},
|
||||
name: 'VersionTest2b',
|
||||
type: 'n8n-nodes-base.versionTest',
|
||||
typeVersion: 2,
|
||||
position: [1080, 300],
|
||||
},
|
||||
],
|
||||
connections: {
|
||||
Start: {
|
||||
main: [
|
||||
[
|
||||
{
|
||||
node: 'VersionTest1a',
|
||||
type: 'main',
|
||||
index: 0,
|
||||
},
|
||||
],
|
||||
],
|
||||
},
|
||||
VersionTest1a: {
|
||||
main: [
|
||||
[
|
||||
{
|
||||
node: 'VersionTest1b',
|
||||
type: 'main',
|
||||
index: 0,
|
||||
},
|
||||
],
|
||||
],
|
||||
},
|
||||
VersionTest1b: {
|
||||
main: [
|
||||
[
|
||||
{
|
||||
node: 'VersionTest2a',
|
||||
type: 'main',
|
||||
index: 0,
|
||||
},
|
||||
],
|
||||
],
|
||||
},
|
||||
VersionTest2a: {
|
||||
main: [
|
||||
[
|
||||
{
|
||||
node: 'VersionTest2b',
|
||||
type: 'main',
|
||||
index: 0,
|
||||
},
|
||||
],
|
||||
],
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
output: {
|
||||
nodeExecutionOrder: [
|
||||
'Start',
|
||||
'VersionTest1a',
|
||||
'VersionTest1b',
|
||||
'VersionTest2a',
|
||||
'VersionTest2b',
|
||||
],
|
||||
nodeData: {
|
||||
VersionTest1a: [
|
||||
[
|
||||
{
|
||||
versionFromNode: 1,
|
||||
versionFromParameter: 1,
|
||||
},
|
||||
],
|
||||
],
|
||||
VersionTest1b: [
|
||||
[
|
||||
{
|
||||
versionFromNode: 1,
|
||||
versionFromParameter: 11,
|
||||
},
|
||||
],
|
||||
],
|
||||
VersionTest2a: [
|
||||
[
|
||||
{
|
||||
versionFromNode: 2,
|
||||
versionFromParameter: 2,
|
||||
},
|
||||
],
|
||||
],
|
||||
VersionTest2b: [
|
||||
[
|
||||
{
|
||||
versionFromNode: 2,
|
||||
versionFromParameter: 22,
|
||||
},
|
||||
],
|
||||
],
|
||||
},
|
||||
},
|
||||
},
|
||||
];
|
||||
|
||||
const fakeLogger = {
|
||||
|
||||
Reference in New Issue
Block a user