Skip to content

Commit

Permalink
Merge pull request #25 from bpedersen/bug/issue18_jest_27_broken
Browse files Browse the repository at this point in the history
Removed workaround for jest@27
  • Loading branch information
bpedersen authored Sep 30, 2021
2 parents cc28bcd + bcc3fa6 commit 863c82a
Show file tree
Hide file tree
Showing 4 changed files with 70 additions and 44 deletions.
10 changes: 2 additions & 8 deletions Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -83,17 +83,11 @@ However you always need to restore the console after each test or you will break
If you don't want to worry about accidentally forgetting to `restoreConsole()` after your tests you can modify jest to unmock after every `it(...)`.

In your jest config:

```javascript
setupFilesAfterEnv: [
"jest-mock-console/dist/setupTestFramework.js",
]
```
If you are using jest@27 you will need to add the following as well:
```javascript
testRunner: "jest-jasmine2"
setupFilesAfterEnv: ["jest-mock-console/dist/setupTestFramework.js"];
```


Then in your test files:

```javascript
Expand Down
32 changes: 14 additions & 18 deletions dist/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ Object.defineProperty(exports, "__esModule", {
});
exports.default = void 0;

function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

Expand All @@ -23,23 +23,19 @@ var mockConsole = function mockConsole(mockArg) {
});
} // Argument is a string
else if (typeof mockArg === 'string' || mockArg instanceof String) {
global.console[mockArg] = jest.fn();
} // Argument is an array
else if (Array.isArray(mockArg)) {
mockArg.forEach(function (key) {
global.console[key] = jest.fn();
});
} // Argument is an object
else {
Object.keys(mockArg).forEach(function (key) {
global.console[key] = mockArg[key];
});
} // Return function to restore console


var restore = function restore() {
return global.console = originalConsole;
};
global.console[mockArg] = jest.fn();
} // Argument is an array
else if (Array.isArray(mockArg)) {
mockArg.forEach(function (key) {
global.console[key] = jest.fn();
});
} // Argument is an object
else {
Object.keys(mockArg).forEach(function (key) {
global.console[key] = mockArg[key];
});
} // Return function to restore console


return function () {
global.console = originalConsole;
Expand Down
70 changes: 53 additions & 17 deletions dist/setupTestFramework.js
Original file line number Diff line number Diff line change
@@ -1,29 +1,65 @@
"use strict";

function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }

function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }

function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }

var originalDescribe = jasmine.getEnv().describe;
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }

jasmine.getEnv().describe = function (description, specDefinitions) {
var $jestMockConsoleOriginal;
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }

var injectedSpecDefinition = function injectedSpecDefinition() {
beforeEach(function () {
$jestMockConsoleOriginal = _objectSpread({}, console);
});
afterEach(function () {
global.console = $jestMockConsoleOriginal;
});
specDefinitions.apply(void 0, arguments);
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }

function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }

function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }

function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }

var originalDescribe = describe; // Check to see if version before 27 where jasmine is default

var jestVersion = require("jest/package.json").version;

var _jestVersion$split = jestVersion.split("."),
_jestVersion$split2 = _slicedToArray(_jestVersion$split, 1),
majorVersion = _jestVersion$split2[0];

if (majorVersion < 27) {
jasmine.getEnv().describe = function (description, specDefinitions) {
var $jestMockConsoleOriginal;

var injectedSpecDefinition = function injectedSpecDefinition() {
beforeEach(function () {
$jestMockConsoleOriginal = _objectSpread({}, console);
});
afterEach(function () {
global.console = $jestMockConsoleOriginal;
});
specDefinitions.apply(void 0, arguments);
};

for (var _len = arguments.length, describeArgs = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
describeArgs[_key - 2] = arguments[_key];
}

return originalDescribe.apply(void 0, [description, injectedSpecDefinition].concat(describeArgs));
};
} else {
describe = function describe(description, specDefinitions) {
var $jestMockConsoleOriginal;

for (var _len = arguments.length, describeArgs = new Array(_len > 2 ? _len - 2 : 0), _key = 2; _key < _len; _key++) {
describeArgs[_key - 2] = arguments[_key];
}
var injectedSpecDefinition = function injectedSpecDefinition() {
beforeEach(function () {
$jestMockConsoleOriginal = _objectSpread({}, console);
});
afterEach(function () {
global.console = $jestMockConsoleOriginal;
});
return specDefinitions.apply(void 0, arguments);
};

return originalDescribe.apply(void 0, [description, injectedSpecDefinition].concat(describeArgs));
};
return originalDescribe(description, injectedSpecDefinition);
};
}
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "jest-mock-console",
"version": "1.1.0",
"version": "1.2.0",
"description": "Jest utility to mock the console",
"main": "index.js",
"types": "index.d.ts",
Expand Down

0 comments on commit 863c82a

Please sign in to comment.