enhance-assert.js 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. 'use strict';
  2. const concordance = require('concordance');
  3. const dotProp = require('dot-prop');
  4. const generate = require('@babel/generator').default;
  5. const concordanceOptions = require('./concordance-options').default;
  6. // When adding patterns, don't forget to add to
  7. // https://github.com/avajs/babel-preset-transform-test-files/blob/master/espower-patterns.json
  8. // Then release a new version of that preset and bump the SemVer range here.
  9. const PATTERNS = [
  10. 't.truthy(value, [message])',
  11. 't.falsy(value, [message])',
  12. 't.true(value, [message])',
  13. 't.false(value, [message])',
  14. 't.regex(contents, regex, [message])',
  15. 't.notRegex(contents, regex, [message])'
  16. ];
  17. const computeStatement = node => generate(node).code;
  18. const getNode = (ast, path) => dotProp.get(ast, path.replace(/\//g, '.'));
  19. const formatter = context => {
  20. const ast = JSON.parse(context.source.ast);
  21. const args = context.args[0].events;
  22. return args
  23. .map(arg => {
  24. const node = getNode(ast, arg.espath);
  25. const statement = computeStatement(node);
  26. const formatted = concordance.format(arg.value, concordanceOptions);
  27. return [statement, formatted];
  28. })
  29. .reverse();
  30. };
  31. const enhanceAssert = (pass, fail, assertions) => {
  32. const empower = require('empower-core');
  33. return empower(assertions, {
  34. destructive: true,
  35. onError(event) {
  36. const error = event.error;
  37. if (event.powerAssertContext) { // Context may be missing in internal tests.
  38. error.statements = formatter(event.powerAssertContext);
  39. }
  40. fail(this, error);
  41. },
  42. onSuccess() {
  43. pass(this);
  44. },
  45. patterns: PATTERNS,
  46. bindReceiver: false
  47. });
  48. };
  49. module.exports = enhanceAssert;