Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Multiple 'catch' node in a flow causes "already registered" error #71

Open
DraggonFantasy opened this issue Nov 17, 2023 · 0 comments
Open

Comments

@DraggonFantasy
Copy link

If the flow contains several 'catch' nodes (which are loaded by test-helper automatically as well as 'status' and 'complete' nodes which possibly will result in the same error), the tests crash with "catch already registered" error.
The reason is probably with this code in index.js:

        testFlow.forEach(n => {
            if (this._nodeModules.hasOwnProperty(n.type)) {
                // Go find the 'real' core node module and load it...
                const result = this._nodeModules[n.type](red);
                if (result?.then) {
                    initPromises.push(result)
                }
                preloadedCoreModules.add(this._nodeModules[n.type]);
            }
        })

Which loads the core nodes without checking if they are already loaded in preloadedCoreModules.

As a workaround, I'm resetting helper._nodeModules before doing helper.load(), so it will not load any core nodes automatically, and then pass them to helper.load() manually

helper._nodeModules = {}
helper.load(coreNodes, flow, function () {
   ....
})
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant