You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

update.spec.js 2.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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: '400',
  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: 'PATCH',
  32. url: `/${params.profile_id}/update/1`,
  33. payload: [
  34. {
  35. response_id: 1,
  36. profile_id: 38,
  37. response_key_id: 6,
  38. val: '999',
  39. },
  40. {
  41. response_id: 2,
  42. profile_id: 38,
  43. response_key_id: 7,
  44. val: '999',
  45. },
  46. ],
  47. }
  48. test(`path ${pathToTest.url} should return ok on ${pathToTest.method}`, async t => {
  49. /**
  50. * Create a new server and register services,
  51. * models and routes for testing
  52. * -
  53. * NOTE: We use a mocked registerModel() and register
  54. * models manually. Normally this is handled by
  55. * Schwifty at runtime.
  56. */
  57. const server = Hapi.server()
  58. /**
  59. * Overload so we don't register any models
  60. * using the plugin call (see plugins/profile.js)
  61. * and Manually load the model we need for the test
  62. */
  63. server.registerModel = () => {}
  64. server.models = () => ({ Response, ResponseKey })
  65. /**
  66. * Register Routes and Services as usual
  67. */
  68. await plugin.register(server)
  69. /**
  70. * Replace Objection model methods with our own mock functions
  71. * !: Janky - might be better to temp knex sqlite instance
  72. */
  73. stub(server.models()['Response'], 'query').returns({
  74. where: () => {
  75. mockReturn.responses.forEach(res => {
  76. res.val = '999'
  77. })
  78. return mockReturn.responses
  79. },
  80. update: () => ({
  81. where: () => ({
  82. where: () => {},
  83. }),
  84. }),
  85. })
  86. /**
  87. * Test the server with registered models and services
  88. */
  89. const { payload } = await server.inject(pathToTest)
  90. const res = JSON.parse(payload)
  91. t.deepEqual(res.ok, true)
  92. t.deepEqual(res.data, mockReturn.responses)
  93. server.stop()
  94. })