callback.js 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. const mockOauthState = require('../mockoauthstate')()
  2. // eslint-disable-next-line import/order
  3. const request = require('supertest')
  4. const tokenService = require('../../src/server/helpers/jwt')
  5. const { getServer } = require('../mockserver')
  6. jest.mock('../../src/server/helpers/oauth-state', () => ({
  7. ...jest.requireActual('../../src/server/helpers/oauth-state'),
  8. ...mockOauthState,
  9. }))
  10. const authServer = getServer()
  11. const authData = {
  12. dropbox: 'token value',
  13. drive: 'token value',
  14. }
  15. const token = tokenService.generateEncryptedToken(authData, process.env.COMPANION_SECRET)
  16. describe('test authentication callback', () => {
  17. test('authentication callback redirects to send-token url', () => {
  18. return request(authServer)
  19. .get('/drive/callback')
  20. .expect(302)
  21. .expect((res) => {
  22. expect(res.header.location).toContain('http://localhost:3020/drive/send-token?uppyAuthToken=')
  23. })
  24. })
  25. test('the token gets sent via cookie and html', () => {
  26. // see mock ../../src/server/helpers/oauth-state above for state values
  27. return request(authServer)
  28. .get(`/dropbox/send-token?uppyAuthToken=${token}&state=state-with-newer-version`)
  29. .expect(200)
  30. .expect((res) => {
  31. const authToken = res.header['set-cookie'][0].split(';')[0].split('uppyAuthToken--dropbox=')[1]
  32. expect(authToken).toEqual(token)
  33. const body = `
  34. <!DOCTYPE html>
  35. <html>
  36. <head>
  37. <meta charset="utf-8" />
  38. <script>
  39. window.opener.postMessage({"token":"${token}"}, "http:\\u002F\\u002Flocalhost:3020")
  40. window.close()
  41. </script>
  42. </head>
  43. <body></body>
  44. </html>`
  45. expect(res.text).toBe(body)
  46. })
  47. })
  48. })