UNPKG

zapier-platform-cli

Version:

The CLI for managing integrations in Zapier Developer Platform.

66 lines (56 loc) 2.07 kB
/* globals describe, it, expect, beforeAll */ const zapier = require('zapier-platform-core'); zapier.tools.env.inject(); // read from the .env file const App = require('../index'); const appTester = zapier.createAppTester(App); // You should create a `.env` file and populate it with your actual Trello // client ID and secret (called "API Key" and "API Secret" by Trello), which you // can find on https://trello.com/app-key. // The `.env` file should look like /* CLIENT_ID=<trello_api_key> CLIENT_SECRET=<trello_api_secret> */ // then you can delete the following 2 lines process.env.CLIENT_ID = process.env.CLIENT_ID || '<trello_api_key>'; process.env.CLIENT_SECRET = process.env.CLIENT_SECRET || '<trello_api_secret>'; describe('oauth1 app', () => { beforeAll(() => { // It's a good idea to store your Client ID and Secret in the environment rather than in code. if (!(process.env.CLIENT_ID && process.env.CLIENT_SECRET)) { throw new Error( `Before running the tests, make sure CLIENT_ID and CLIENT_SECRET are available in the environment.` ); } }); it('fetch a request token', async () => { const bundle = { inputData: { // You should add your redirect URI to https://trello.com/app-key redirect_uri: 'https://zapier.com', }, }; const tokens = await appTester( App.authentication.oauth1Config.getRequestToken, bundle ); expect(tokens).toHaveProperty('oauth_token'); expect(tokens).toHaveProperty('oauth_token_secret'); }); it('generates an authorize URL', async () => { const bundle = { // In production, these will be generated by Zapier and set automatically inputData: { oauth_token: '4444', redirect_uri: 'https://zapier.com/', }, }; const authorizeUrl = await appTester( App.authentication.oauth1Config.authorizeUrl, bundle ); expect(authorizeUrl).toBe( 'https://trello.com/1/OAuthAuthorizeToken?oauth_token=4444&name=Zapier%2FTrello%20OAuth1%20Test' ); }); });