Skip to content

Commit a676040

Browse files
committed
String 2.1.0
1 parent 266891c commit a676040

File tree

8 files changed

+44
-21
lines changed

8 files changed

+44
-21
lines changed

.editorconfig

Lines changed: 6 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -1,18 +1,17 @@
1-
# EditorConfig: http://EditorConfig.org
1+
# EditorConfig is awesome: https://EditorConfig.org
22

3-
# top-most EditorConfig file
43
root = true
54

6-
# Unix-style newlines with a newline ending every file
75
[*]
8-
charset = utf-8
96
end_of_line = lf
10-
trim_trailing_whitespace = true
117
insert_final_newline = true
8+
9+
[*.{js,d.ts,ts}]
10+
charset = utf-8
11+
trim_trailing_whitespace = true
1212
indent_style = space
1313
indent_size = 4
1414

15-
# 2 space indentation
16-
[*.yaml, *.yml]
15+
[package.json,*.yaml]
1716
indent_style = space
1817
indent_size = 2

.gitattributes

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
* text=auto eol=lf

.gitignore

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
# Global
22
node_modules/
3+
coverage
34

45
# OS Generated
56
.DS_Store*

index.d.ts

Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
interface Options {
2+
length?: number;
3+
keyspace?: string;
4+
}
5+
export default function string(options?: Options): string;

index.js

Lines changed: 7 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,13 +1,15 @@
11
export default function string(options) {
22
options = options || {};
3-
let length = options.length || 64;
4-
let keyspace = options.keyspace || '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
5-
let pieces = [];
3+
let length = options.length === undefined ? 64 : options.length;
4+
const keyspace = options.keyspace || '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
5+
const pieces = [];
66
if (length < 0) {
77
length = 1;
88
}
9-
for (var i = 0; i < length; i++) {
9+
10+
for (let i = 0; i < length; i++) {
1011
pieces.push(keyspace.charAt(Math.floor(Math.random() * keyspace.length)));
1112
}
13+
1214
return pieces.join('');
13-
};
15+
}

index.test-d.ts

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,7 @@
1+
import {expectType} from 'tsd';
2+
import string from './index.js';
3+
4+
expectType<string>(string());
5+
expectType<string>(string({length: -1}));
6+
expectType<string>(string({length: 10}));
7+
expectType<string>(string({length: 10, keyspace: '0123456789'}));

package.json

Lines changed: 8 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
{
22
"name": "@fakerjs/string",
3-
"version": "2.0.1",
3+
"version": "2.1.0",
44
"description": "String package provides functionality to generate a fake string value.",
55
"license": "MIT",
66
"repository": "faker-javascript/string",
@@ -15,13 +15,17 @@
1515
"node": ">=12"
1616
},
1717
"scripts": {
18-
"test": "ava"
18+
"test": "c8 ava; xo --space 4; tsd;"
1919
},
2020
"devDependencies": {
21-
"ava": "^3.15.0"
21+
"ava": "^4.0.0",
22+
"c8": "^7.11.0",
23+
"tsd": "^0.19.1",
24+
"xo": "^0.47.0"
2225
},
2326
"files": [
24-
"index.js"
27+
"index.js",
28+
"index.d.ts"
2529
],
2630
"keywords": [
2731
"fakerjs",

test.js

Lines changed: 9 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,18 @@
1-
import string from './index.js';
21
import test from 'ava';
2+
import string from './index.js';
33

44
test('string return type to be string', t => {
5-
t.is(typeof string(), 'string');
5+
t.is(typeof string(), 'string');
66
});
77

88
test('string length is 10', t => {
9-
t.is(string({length: 10}).length, 10);
9+
t.is(string({length: 10}).length, 10);
10+
});
11+
12+
test('string length is -1', t => {
13+
t.is(string({length: -1}).length, 1);
1014
});
1115

1216
test('string length is 10 with keyspace 0123456789', t => {
13-
t.is(string({length: 10, keyspace: '0123456789'}).length, 10);
14-
});
17+
t.is(string({length: 10, keyspace: '0123456789'}).length, 10);
18+
});

0 commit comments

Comments
 (0)