forked from M3-Academy/challenge-algorithms-v2.0
77 lines
2.1 KiB
JavaScript
77 lines
2.1 KiB
JavaScript
"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);
|
|
});
|
|
});
|
|
});
|