style: Added and ran prettier.

This commit is contained in:
Spencer Brower
2023-05-25 17:31:52 -04:00
parent 2952a1cfef
commit 7f8ef72f19
11 changed files with 284 additions and 240 deletions

View File

@@ -1,155 +1,172 @@
import { describe, expect, it } from 'vitest';
import fc from 'fast-check';
import { describe, expect, it } from "vitest";
import fc from "fast-check";
import {
/*afterFirstWord, beforeFirstWord, */ afterFirst, afterLast, endsWith, ltrim, rtrim, trim, startsWith, beforeFirst,
} from './index';
/*afterFirstWord, beforeFirstWord, */ afterFirst,
afterLast,
endsWith,
ltrim,
rtrim,
trim,
startsWith,
beforeFirst,
} from "./index";
describe('strings', () => {
describe('startsWith', () => {
it('returns true if haystack starts with needle', () => {
expect(startsWith('foo', 'foobar')).toBe(true);
})
it('returns true when haystack is needle', () => {
expect(startsWith('foo', 'foo')).toBe(true);
})
it('works', () => {
fc.assert(fc.property(fc.string(), fc.string(), (needle, haystack) => {
if (haystack.indexOf(needle) == 0) {
expect(startsWith(needle, haystack)).toBe(true);
}
}));
})
describe("strings", () => {
describe("startsWith", () => {
it("returns true if haystack starts with needle", () => {
expect(startsWith("foo", "foobar")).toBe(true);
});
describe('endsWith', () => {
it('returns true if haystack end with needle', () => {
expect(endsWith('bar', 'foobar')).toBe(true);
})
it('returns true when haystack is needle', () => {
expect(endsWith('foo', 'foo')).toBe(true);
})
it('works', () => {
fc.assert(fc.property(fc.string(), fc.string(), (needle, haystack) => {
if (haystack.substring(haystack.indexOf(needle)) == needle) {
expect(endsWith(needle, haystack)).toBe(true);
}
}));
})
it("returns true when haystack is needle", () => {
expect(startsWith("foo", "foo")).toBe(true);
});
describe('afterFirst', () => {
it('removes everything before the first needle when possible', () => {
expect(afterFirst(' ', 'foo bar bat')).toBe('bar bat');
})
it('removes nothing when needle is not present', () => {
expect(afterFirst('&', 'foo bar bat')).toBe('foo bar bat');
})
})
describe('afterLast', () => {
it('removes everything after the last needle when possible', () => {
expect(afterLast(' ', 'foo bar bat')).toBe('bat');
})
it('removes nothing when needle is not present', () => {
expect(afterLast('&', 'foo bar bat')).toBe('foo bar bat');
})
})
describe('beforeFirst', () => {
it('removes everything after the first needle when possible', () => {
expect(beforeFirst(' ', 'foo bar bat')).toBe('foo');
})
it('removes everythin when needle is not present', () => {
expect(beforeFirst('&', 'foo bar bat')).toBe('');
})
})
// describe('afterFirstWord', () => {
// it('removes the first word', () => {
// fc.assert(fc.property(fc.string(), (str) => {
// const got = afterFirstWord(str);
// if (got !== '') {
// expect(endsWith(got, str)).toBe(true);
// if (str.indexOf(' ') !== -1) {
// expect(`${beforeFirstWord(str)} ${got}`).toBe(str);
// }
// }
// }));
// });
// });
describe('ltrim', () => {
it('returns input when cutset is empty', () => {
expect(ltrim('', 'foo')).toBe('foo');
});
it('returns empty when input is empty', () => {
expect(ltrim('foo', '')).toBe('');
});
it('can be curried', () => {
expect(ltrim('foo', '')).toBe(ltrim('foo')(''));
expect(ltrim(' ', ' foo')).toBe(ltrim(' ')(' foo'));
});
it('trims cutset', () => {
fc.assert(fc.property(fc.string(), fc.string(), (cutset, str) => {
const got = ltrim(cutset, str);
if (cutset === '') {
expect(got).toBe(str);
} else if (str === '') {
expect(got).toBe('');
} else {
if (got === '') {
for (const char of str) {
expect(cutset).contains(char);
}
it("works", () => {
fc.assert(
fc.property(fc.string(), fc.string(), (needle, haystack) => {
if (haystack.indexOf(needle) == 0) {
expect(startsWith(needle, haystack)).toBe(true);
}
for (const char of cutset) {
expect(startsWith(char, got)).toBe(false);
})
);
});
});
describe("endsWith", () => {
it("returns true if haystack end with needle", () => {
expect(endsWith("bar", "foobar")).toBe(true);
});
it("returns true when haystack is needle", () => {
expect(endsWith("foo", "foo")).toBe(true);
});
it("works", () => {
fc.assert(
fc.property(fc.string(), fc.string(), (needle, haystack) => {
if (haystack.substring(haystack.indexOf(needle)) == needle) {
expect(endsWith(needle, haystack)).toBe(true);
}
}
}));
})
);
});
});
describe("afterFirst", () => {
it("removes everything before the first needle when possible", () => {
expect(afterFirst(" ", "foo bar bat")).toBe("bar bat");
});
it("removes nothing when needle is not present", () => {
expect(afterFirst("&", "foo bar bat")).toBe("foo bar bat");
});
});
describe("afterLast", () => {
it("removes everything after the last needle when possible", () => {
expect(afterLast(" ", "foo bar bat")).toBe("bat");
});
it("removes nothing when needle is not present", () => {
expect(afterLast("&", "foo bar bat")).toBe("foo bar bat");
});
});
describe('rtrim', () => {
it('returns input when cutset is empty', () => {
expect(rtrim('', 'foo')).toBe('foo');
describe("beforeFirst", () => {
it("removes everything after the first needle when possible", () => {
expect(beforeFirst(" ", "foo bar bat")).toBe("foo");
});
it('returns empty when input is empty', () => {
expect(rtrim('foo', '')).toBe('');
});
it('can be curried', () => {
expect(rtrim('foo', '')).toBe(rtrim('foo')(''));
expect(rtrim(' ', ' foo')).toBe(rtrim(' ')(' foo'));
});
it('trims cutset', () => {
fc.assert(fc.property(fc.string(), fc.string(), (cutset, str) => {
const got = rtrim(cutset, str);
if (cutset === '') {
expect(got).toBe(str);
} else if (str === '') {
expect(got).toBe('');
} else {
if (got === '') {
for (const char of str) {
expect(cutset).contains(char);
it("removes everythin when needle is not present", () => {
expect(beforeFirst("&", "foo bar bat")).toBe("");
});
});
// describe('afterFirstWord', () => {
// it('removes the first word', () => {
// fc.assert(fc.property(fc.string(), (str) => {
// const got = afterFirstWord(str);
// if (got !== '') {
// expect(endsWith(got, str)).toBe(true);
// if (str.indexOf(' ') !== -1) {
// expect(`${beforeFirstWord(str)} ${got}`).toBe(str);
// }
// }
// }));
// });
// });
describe("ltrim", () => {
it("returns input when cutset is empty", () => {
expect(ltrim("", "foo")).toBe("foo");
});
it("returns empty when input is empty", () => {
expect(ltrim("foo", "")).toBe("");
});
it("can be curried", () => {
expect(ltrim("foo", "")).toBe(ltrim("foo")(""));
expect(ltrim(" ", " foo")).toBe(ltrim(" ")(" foo"));
});
it("trims cutset", () => {
fc.assert(
fc.property(fc.string(), fc.string(), (cutset, str) => {
const got = ltrim(cutset, str);
if (cutset === "") {
expect(got).toBe(str);
} else if (str === "") {
expect(got).toBe("");
} else {
if (got === "") {
for (const char of str) {
expect(cutset).contains(char);
}
}
for (const char of cutset) {
expect(startsWith(char, got)).toBe(false);
}
}
for (const char of cutset) {
expect(endsWith(char, got)).toBe(false);
}
}
}));
})
);
});
});
describe('trim', () => {
it("composes 'ltrim' and 'rtrim'", function() {
fc.assert(fc.property(fc.string(), fc.string(), (cutset, str) => {
expect(trim(cutset, str)).toBe(ltrim(cutset, rtrim(cutset, str)));
}));
describe("rtrim", () => {
it("returns input when cutset is empty", () => {
expect(rtrim("", "foo")).toBe("foo");
});
})
});
it("returns empty when input is empty", () => {
expect(rtrim("foo", "")).toBe("");
});
it("can be curried", () => {
expect(rtrim("foo", "")).toBe(rtrim("foo")(""));
expect(rtrim(" ", " foo")).toBe(rtrim(" ")(" foo"));
});
it("trims cutset", () => {
fc.assert(
fc.property(fc.string(), fc.string(), (cutset, str) => {
const got = rtrim(cutset, str);
if (cutset === "") {
expect(got).toBe(str);
} else if (str === "") {
expect(got).toBe("");
} else {
if (got === "") {
for (const char of str) {
expect(cutset).contains(char);
}
}
for (const char of cutset) {
expect(endsWith(char, got)).toBe(false);
}
}
})
);
});
});
describe("trim", () => {
it("composes 'ltrim' and 'rtrim'", function () {
fc.assert(
fc.property(fc.string(), fc.string(), (cutset, str) => {
expect(trim(cutset, str)).toBe(ltrim(cutset, rtrim(cutset, str)));
})
);
});
});
});