..
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77 | import type { Faker } from '.';
export class Database {
constructor(private readonly faker: Faker) {
// Bind `this` so namespaced is working correctly
for (const name of Object.getOwnPropertyNames(Database.prototype)) {
if (name === 'constructor' || typeof this[name] !== 'function') {
continue;
}
this[name] = this[name].bind(this);
}
// TODO @Shinigami92 2022-01-11: We should find a better strategy as assigning this property to a function
// @ts-expect-error
this.column.schema = {
description: 'Generates a column name.',
sampleResults: ['id', 'title', 'createdAt'],
};
// @ts-expect-error
this.type.schema = {
description: 'Generates a column type.',
sampleResults: ['byte', 'int', 'varchar', 'timestamp'],
};
// @ts-expect-error
this.collation.schema = {
description: 'Generates a collation.',
sampleResults: ['utf8_unicode_ci', 'utf8_bin'],
};
// @ts-expect-error
this.engine.schema = {
description: 'Generates a storage engine.',
sampleResults: ['MyISAM', 'InnoDB'],
};
}
/**
* column
*
* @method faker.database.column
*/
column(): string {
return this.faker.random.arrayElement(
this.faker.definitions.database.column
);
}
/**
* type
*
* @method faker.database.type
*/
type(): string {
return this.faker.random.arrayElement(this.faker.definitions.database.type);
}
/**
* collation
*
* @method faker.database.collation
*/
collation(): string {
return this.faker.random.arrayElement(
this.faker.definitions.database.collation
);
}
/**
* engine
*
* @method faker.database.engine
*/
engine(): string {
return this.faker.random.arrayElement(
this.faker.definitions.database.engine
);
}
}
|
|