diff --git a/.github/workflows/prod_ci.yml b/.github/workflows/prod_ci.yml new file mode 100644 index 0000000..ec3f8e9 --- /dev/null +++ b/.github/workflows/prod_ci.yml @@ -0,0 +1,32 @@ +name: e2e prod test +on: + push: + branches: + - master + tags: + - v[0-9]+.[0-9]+.[0-9]+* + pull_request: + branches: + - master +jobs: + test: + name: Run tests and publish test coverage + runs-on: ubuntu-latest + strategy: + matrix: + node-version: [18.x] + # See supported Node.js release schedule at https://nodejs.org/en/about/releases/ + steps: + - uses: actions/checkout@v2 + - name: Use Node.js ${{ matrix.node-version }} + uses: actions/setup-node@v2 + with: + node-version: ${{ matrix.node-version }} + cache: 'npm' + - name: Install dependencies + run: npm install + - name: Run tests + run: npm run env -- mocha --timeout 10000 --recursive --require babel-register test_prod/ + env: + API_KEY: ${{ secrets.API_KEY }} + API_SECRET: ${{ secrets.API_SECRET }} diff --git a/test_prod/razorpay.js b/test_prod/razorpay.js new file mode 100644 index 0000000..5c2c49c --- /dev/null +++ b/test_prod/razorpay.js @@ -0,0 +1,25 @@ +'use strict'; + +const Razorpay = require("../dist/razorpay"); +let request = require('request-promise'); + +class RazorpayBeta extends Razorpay { + constructor(options) { + super(options) + this.api.rq = request.defaults({ + baseUrl: options.hostUrl, + json: true, + auth: { + user: options.key_id, + pass: options.key_secret + } + }) + } +} + + +module.exports = new RazorpayBeta({ + key_id: process.env.API_KEY || "", + key_secret: process.env.API_SECRET || "", + hostUrl : "https://api-web.dev.razorpay.in" +}); diff --git a/test_prod/resources/addon.spec.js b/test_prod/resources/addon.spec.js new file mode 100644 index 0000000..a493262 --- /dev/null +++ b/test_prod/resources/addon.spec.js @@ -0,0 +1,32 @@ +'use strict' + +var assert = require('assert'); +const rzpInstance = require('../razorpay') +const equal = require('deep-equal'); +const { items } = require('../razorpay'); + +let addonId = null; + +describe('ADDON', () => { + + it('Fetch all addons', (done) => { + + rzpInstance.addons.all({ "count": 1 }).then((response) => { + if (response.hasOwnProperty('items')) { + if ('id' in response.items[0]) { + addonId = response.items[0].id + } + } + assert.ok(response.hasOwnProperty('count')) + assert.ok(response.hasOwnProperty('items')) + done() + }).catch(err => console.log(err)) + }) + + it('fetch order\'s payments', (done) => { + rzpInstance.addons.fetch(addonId).then((response) => { + assert.ok(response.hasOwnProperty('id')) + done() + }) + }) +}) diff --git a/test_prod/resources/cards.spec.js b/test_prod/resources/cards.spec.js new file mode 100644 index 0000000..d5cbc26 --- /dev/null +++ b/test_prod/resources/cards.spec.js @@ -0,0 +1,17 @@ +'use strict' + +var assert = require('assert'); +const rzpInstance = require('../razorpay') +const equal = require('deep-equal'); +const { items } = require('../razorpay'); + +let cardId = "card_LcQgzpfvWP0UKF"; + +describe('CARDS', () => { + it('fetch order\'s payments', (done) => { + rzpInstance.cards.fetch(cardId).then((response) => { + assert.ok(response.hasOwnProperty('id')) + done() + }) + }) +})