"use strict"; var jsc = require("jsverify"); var refute = require("@sinonjs/referee-sinon").refute; var functionName = require("./function-name"); describe("function-name", function() { it("should return empty string if func is falsy", function() { jsc.assertForall("falsy", function(fn) { return functionName(fn) === ""; }); }); it("should use displayName by default", function() { jsc.assertForall("nestring", function(displayName) { var fn = { displayName: displayName }; return functionName(fn) === fn.displayName; }); }); it("should use name if displayName is not available", function() { jsc.assertForall("nestring", function(name) { var fn = { name: name }; return functionName(fn) === fn.name; }); }); it("should fallback to string parsing", function() { jsc.assertForall("nat", function(naturalNumber) { var name = "fn" + naturalNumber; var fn = { toString: function() { return "\nfunction " + name; } }; return functionName(fn) === name; }); }); it("should not fail when a name cannot be found", function() { refute.exception(function() { var fn = { toString: function() { return "\nfunction ("; } }; functionName(fn); }); }); it("should not fail when toString is undefined", function() { refute.exception(function() { functionName(Object.create(null)); }); }); it("should not fail when toString throws", function() { refute.exception(function() { var fn; try { // eslint-disable-next-line no-eval fn = eval("(function*() {})")().constructor; } catch (e) { // env doesn't support generators return; } functionName(fn); }); }); });