UNPKG

node-red-contrib-oauth2

Version:

The node-red-contrib-oauth2 is a Node-RED node that provides an OAuth2 authentication flow. This node uses the OAuth2 protocol to obtain an access token, which can be used to make authenticated API requests.

124 lines (109 loc) 4.38 kB
const should = require('should'); // eslint-disable-line no-unused-vars const helper = require('node-red-node-test-helper'); const nock = require('nock'); const oauth2Node = require('node-red-contrib-oauth2/src/oauth2.js'); helper.init(require.resolve('node-red')); describe('OAuth2 Node Error Handling', function () { before(function (done) { this.timeout(20000); // Increase timeout to 20000ms for more room console.log('Starting Node-RED server...'); helper.startServer(done); }); after(function (done) { this.timeout(20000); // Increase timeout to 20000ms for more room console.log('Stopping Node-RED server...'); helper.stopServer(done); }); afterEach(function (done) { console.log('Unloading flows...'); helper.unload().then(function () { nock.cleanAll(); done(); }); }); it('should handle errors', function (done) { this.timeout(10000); // Set timeout for individual test console.log('Testing error handling...'); const flow = [ { id: 'n1', type: 'oauth2', name: 'oauth2', wires: [[], ['n3']] }, { id: 'n3', type: 'helper' } ]; const credentials = { clientId: 'testClientId', clientSecret: 'testClientSecret' }; helper.load(oauth2Node, flow, credentials, function () { const n1 = helper.getNode('n1'); const n3 = helper.getNode('n3'); console.log('Setting up nock for invalid-url.com...'); const scope = nock('https://invalid-url.com').post('/').replyWithError('mocked error'); n3.on('input', function (msg) { console.log('Received input on error helper node'); try { msg.should.have.property('oauth2Error'); msg.oauth2Error.should.have.property('message', 'mocked error'); scope.done(); // Verify if the nock interceptor was called done(); } catch (err) { console.error('Failed error handling test', err); done(err); } }); console.log('Sending input to node...'); n1.receive({ oauth2Request: { access_token_url: 'https://invalid-url.com', credentials: { grant_type: 'client_credentials', client_id: 'testClientId', client_secret: 'testClientSecret', scope: 'testScope' } } }); }); }); it('should handle invalid client credentials', function (done) { this.timeout(10000); // Set timeout for individual test console.log('Testing invalid client credentials handling...'); const flow = [ { id: 'n1', type: 'oauth2', name: 'oauth2', wires: [[], ['n3']] }, { id: 'n3', type: 'helper' } ]; const credentials = { clientId: 'invalidClientId', clientSecret: 'invalidClientSecret' }; helper.load(oauth2Node, flow, credentials, function () { const n1 = helper.getNode('n1'); const n3 = helper.getNode('n3'); console.log('Setting up nock for example.com...'); const scope = nock('https://example.com').post('/oauth2/token').reply(401, { error: 'invalid_client' }); n3.on('input', function (msg) { console.log('Received input on error helper node'); try { msg.should.have.property('oauth2Error'); msg.oauth2Error.should.have.property('status', 401); msg.oauth2Error.data.should.have.property('error', 'invalid_client'); scope.done(); // Verify if the nock interceptor was called done(); } catch (err) { console.error('Failed invalid client credentials handling test', err); done(err); } }); console.log('Sending input to node...'); n1.receive({ oauth2Request: { access_token_url: 'https://example.com/oauth2/token', credentials: { grant_type: 'client_credentials', client_id: 'invalidClientId', client_secret: 'invalidClientSecret', scope: 'testScope' } } }); }); }); });