Você não pode selecionar mais de 25 tópicos Os tópicos devem começar com uma letra ou um número, podem incluir traços ('-') e podem ter até 35 caracteres.

respond.spec.js 2.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. 'use strict'
  2. const test = require('ava')
  3. const { stub } = require('sinon')
  4. const Hapi = require('@hapi/hapi')
  5. const plugin = require('../lib/plugins/profile')
  6. const Response = require('../lib/models/response')
  7. const ResponseKey = require('../lib/models/response-key')
  8. /**
  9. * Route parameters
  10. */
  11. const params = {
  12. profile_id: 38,
  13. }
  14. const mockReturn = {
  15. responses: [
  16. {
  17. response_id: 1,
  18. profile_id: 38,
  19. response_key_id: 6,
  20. val: '2056',
  21. },
  22. {
  23. response_id: 2,
  24. profile_id: 38,
  25. response_key_id: 7,
  26. val: '90012',
  27. },
  28. ],
  29. }
  30. const pathToTest = {
  31. method: 'POST',
  32. url: `/${params.profile_id}/respond?response_key_id=5&val=2053`,
  33. }
  34. test('path /<profile_id>/respond should return ok on POST', async t => {
  35. /**
  36. * Create a new server and register services,
  37. * models and routes for testing
  38. * -
  39. * NOTE: We use a mocked registerModel() and register
  40. * models manually. Normally this is handled by
  41. * Schwifty at runtime.
  42. */
  43. const server = Hapi.server()
  44. /**
  45. * Overload so we don't register any models
  46. * using the plugin call (see plugins/profile.js)
  47. * and Manually load the model we need for the test
  48. */
  49. server.registerModel = () => {}
  50. server.models = () => ({ Response, ResponseKey })
  51. server.registrations = {
  52. 'main-app-plugin': {
  53. options: {},
  54. },
  55. }
  56. /**
  57. * Register Routes and Services as usual
  58. */
  59. await plugin.register(server)
  60. /**
  61. * Replace Objection model methods with our own mock functions
  62. * !: Janky - might be better to temp knex sqlite instance
  63. */
  64. stub(server.models()['Response'], 'query').returns({
  65. where: () => mockReturn.responses,
  66. insert: response => {
  67. response.response_id = 3
  68. mockReturn.responses.push(response)
  69. },
  70. })
  71. /**
  72. * Test the server with registered models and services
  73. */
  74. const { payload } = await server.inject(pathToTest)
  75. const res = JSON.parse(payload)
  76. t.deepEqual(res.ok, true)
  77. t.deepEqual(res.data, mockReturn.responses)
  78. server.stop()
  79. })