Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feat/claire elastic test #153

Merged
merged 100 commits into from
Oct 14, 2024
Merged
Show file tree
Hide file tree
Changes from 4 commits
Commits
Show all changes
100 commits
Select commit Hold shift + click to select a range
6d4f96e
feat: project init
Jul 18, 2024
9a4e9aa
Revert "feat: project init"
Jul 18, 2024
d456b05
test: test searchEngine Instances
Jul 18, 2024
c6a15be
chore: cleanup
steve-lemon Jul 19, 2024
495a627
feat: add getVersion to get instance version info
Jul 19, 2024
94d0521
feat: add initService for concurrent testing of instances
Jul 19, 2024
b4016e5
feat: add ver-related changes to clearly distinguish vers
Jul 21, 2024
d2cab80
feat: add methods to modularize commons
Jul 21, 2024
c7d7b6a
refactor: review feedback
Jul 22, 2024
f22a209
chore: code review
steve-lemon Jul 22, 2024
4ec5827
feat: add parse-version
Jul 22, 2024
d3d7736
feat: modularize tests
Jul 22, 2024
999f807
refactor: exclude 'type' for 2.13
Jul 22, 2024
ae8140a
refactor: remove "parse-node-version" and add parseVersion method
Jul 23, 2024
2d17966
test: rename methods name
Jul 23, 2024
59624be
refactor: specify params type
Jul 23, 2024
ad32d45
feat: add 404 INDEX NOT FOUND to deleteItem
Jul 23, 2024
9db5ac9
chore: improve error logging in tests
Jul 24, 2024
57f9d80
chore: add comments to interfaces
Jul 24, 2024
3881691
refactor: add isOpenSearch() and exclude _type by result
Jul 24, 2024
04b99c7
chore: change type in Elastic6Service<any> to <MyModel>
Jul 25, 2024
98a4f37
chore: update isOpenSearch version check
Jul 25, 2024
4b9f212
feat: save `info` into `samples/<version>/info.json`
Jul 26, 2024
d200650
test: add test cases for updating w/ mismatched type
Jul 31, 2024
e1bd003
test: add test cases for auto indexing
Aug 1, 2024
c154a14
teat: add mismatchedTypeTest
Aug 1, 2024
04531eb
chore: add update-item.err400.mapping.json
Aug 5, 2024
901447c
test: add getIndexMapping to verify the mapping condition.
Aug 5, 2024
7d915d2
refactor: include root cause in error response
Aug 5, 2024
75ac3b2
chore: change object to object?
Aug 6, 2024
120dc3c
chore: cleanup
steve-lemon Aug 6, 2024
0a770fd
chore: code-review
steve-lemon Aug 6, 2024
03dc68f
test: test w/o network connection
Aug 6, 2024
4fb64d4
chore: improve performance of getVersion()
Aug 6, 2024
fb41ce2
chore: add "!"description to dummy error
Aug 6, 2024
209ea36
test: add totalSummary
Aug 6, 2024
a70c9db
feat: add saveInfoToFile & searchAll
Aug 7, 2024
a657d88
chore: add dummy bulk429error
Aug 7, 2024
80e1990
test: add version parse error test
Aug 7, 2024
6d2f10f
chore: rename dummy err
Aug 7, 2024
3adc5b4
chore: modify comments
Aug 7, 2024
f8154f6
test: optimize common searchRawResult
Aug 7, 2024
b754cb9
refactor: update parseVersion to return error message in response
Aug 7, 2024
2cdf812
refactor: get version from Elastic6Option
Aug 7, 2024
2cf591f
refactor: throw Error when parsedVersion makes err
Aug 8, 2024
da6b385
test: add searchAgent to autoIndexingTest
Aug 8, 2024
b7fbad2
refactor: control parseVersion err w/options.throwable
Aug 8, 2024
d25857a
test: increase test coverage 72 to 84
Aug 8, 2024
c3fd70b
chore: code review
steve-lemon Aug 9, 2024
8fe29ad
fix: test w/o network connection
Aug 9, 2024
67beee1
refactor: modified parseVersion() to parse version into major, minor,…
Aug 9, 2024
cefcdc6
feat: add executeSelfTest()
Aug 9, 2024
57d743a
test: test executeSelfTest
Aug 9, 2024
a19e69a
feat: add aggregationTest w/15000 data
Aug 19, 2024
f22d04e
feat: add searchFilterTest
Aug 21, 2024
f53181d
feat: add inline-function to check version
Aug 23, 2024
af1c022
test: update test code to validate data based on results
Aug 26, 2024
ca5617a
fix: add arguments needed to saveItems
Aug 26, 2024
aa0beed
test: test query-service of each version
Aug 27, 2024
2ce3ea0
test: add matchSearchTest
Aug 28, 2024
6ddecb0
fix: remove checking expectedMatchList2 for 2.13
Aug 28, 2024
c368b29
chore: add comments explaining _score algorithms
Aug 28, 2024
140e4c1
chore: add comments explaining _score algorithms
Aug 28, 2024
82425dc
refactor: modify bulk operation logic to handle dataset in chunks
Aug 29, 2024
29e43c1
chore: code-review
steve-lemon Aug 30, 2024
f8f8014
chore: clean up codes
Aug 30, 2024
6e11568
feat: define the response type `SearchResponse`
Aug 30, 2024
a6883db
test: add empty '' test
Aug 30, 2024
c8d910b
refactor: modify to test using search() only
Aug 30, 2024
dc8001c
feat: add indexItem to overwrite whole docs
Sep 2, 2024
8081461
chore: cleanup
steve-lemon Sep 3, 2024
6cc4dd6
refactor: fix increment of updateItem to work
Sep 3, 2024
038e541
refactor: make updateItem overwrite with script
Sep 3, 2024
292b533
fix: remove indexItem
Sep 5, 2024
7ab5f40
feat: extract the general super class `ElasticIndexService` => versio…
Sep 5, 2024
c624c8e
refactor: improve updateItem for ACID
Sep 5, 2024
16c8d36
chore: fix comments
Sep 9, 2024
b0ad126
test: add doTest
Sep 9, 2024
604f00b
refactor: switch to using Index API for update logic
Sep 9, 2024
ad5ebc6
chore: add comments
Sep 9, 2024
123a4e3
refactor: add incrementItem to updateResponse
Sep 10, 2024
6d14dc5
test: add update readback check
Sep 10, 2024
b529474
feat: prevent overwriting on update, allow overwriting on save
Sep 10, 2024
02b08ad
test: add increment test
Sep 10, 2024
5fd1b1e
feat: support increments in dummy.
Sep 12, 2024
a84be4c
chore: cleanup codes
Sep 12, 2024
719db27
feat: add versionChecking to prepareSettings
Sep 12, 2024
8ccae79
refactor: move isOldES6 logic to Elastic6Service
Sep 23, 2024
645ab63
test: improve test codes
Sep 23, 2024
7602e27
refactor: remove unnecessary if statement
Sep 23, 2024
d3e2a2f
chore: cleanup
steve-lemon Sep 24, 2024
551377c
test: feat _ver()
Sep 24, 2024
c1d7613
refactor: improve update to overwrite extra
Sep 24, 2024
9bec0a9
fix: undo Elastic6Service override
Sep 24, 2024
909f352
test: feat CRUDModel interface
Sep 24, 2024
e4618df
test: add testcase
Sep 26, 2024
cddea0a
feat: add abstarct ElasticIndexService class
Sep 26, 2024
958ea57
chore: opt ElasticItem
steve-lemon Sep 30, 2024
f8756e4
refactor: improve Elastic Classes
Sep 30, 2024
73965b2
test: improve CRUDModel Interface
Sep 30, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
93 changes: 58 additions & 35 deletions src/cores/elastic/elastic6-service.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,55 @@ export const instance = (version: VERSIONS = '6.2', useAutoComplete = false, ind
return { version, service, dummy, options };
};

export const initService = async (
ver: VERSIONS,
): Promise<{ service: Elastic6Service<MyModel>; options: Elastic6Option }> => {
const { service, options } = instance(ver);
const { indexName, idName } = options;

//check hello
const helloResult = service.hello();
expect2(() => helloResult).toEqual(`elastic6-service:${indexName}:${ver}`);

//check idName
expect2(() => idName).toEqual('$id');

//check indexName
expect2(() => indexName).toEqual(`test-v${ver}`);

//check version
expect2(() => service.versionString).toEqual(ver);

return { service, options };
};

export const setupIndex = async (service: Elastic6Service<any>, indexName: string): Promise<void> => {
const PASS = (e: any) => e;

//destroy index
const oldIndex = await service.findIndex(indexName);
if (oldIndex) {
expect2(() => oldIndex, 'index').toEqual({ index: indexName });
expect2(await service.destroyIndex().catch(PASS)).toEqual({
status: 200,
acknowledged: true,
index: indexName,
});
await waited(50);
}

// create index
expect2(await service.createIndex().catch(PASS)).toEqual({
status: 200,
acknowledged: true,
index: indexName,
});
await waited(200);

// fail to create index if already in use
expect2(await service.createIndex().catch(GETERR)).toEqual(`400 IN USE - index:${indexName}`);
};

export const canPerformTest = async (service: Elastic6Service<MyModel>): Promise<boolean> => {
// const { service } = instance();
// cond 1. localhost is able to access elastic6 endpoint (by tunneling)
Expand Down Expand Up @@ -223,33 +272,17 @@ describe('Elastic6Service', () => {
const PASS = (e: any) => e;

//! load dummy storage service.
const ver = ['6.2', '6.8', '7.1', '7.2', '0'][3] as VERSIONS;
const { service, options } = instance(ver);
const { indexName, idName } = options;

expect2(() => service.hello()).toEqual(`elastic6-service:${indexName}:${ver}`);
expect2(() => idName).toEqual('$id');
expect2(() => indexName).toEqual(`test-v${ver}`);
expect2(() => service.version).toEqual(parseFloat(ver));
const { service, options } = await initService('7.10');
const indexName = options.indexName;

//! break if no live connection
if (!(await canPerformTest(service))) return;

await setupIndex(service, indexName);

// const expectedDesc = loadJsonSync('data/samples/es7.1/describe-ok.json');
// expect2(await service.describe().catch(PASS)).toEqual(expectedDesc);

//! make sure the index destroyed.
const $old = await service.findIndex(indexName);
if ($old) {
expect2(() => $old, 'index').toEqual({ index: indexName });
expect2(await service.destroyIndex().catch(PASS)).toEqual({
status: 200,
acknowledged: true,
index: indexName,
});
await waited(50);
}

// expect2(await service.destroyIndex().catch(PASS)).toEqual();
// expect2(await service.refreshIndex().catch(PASS)).toEqual();
// expect2(await service.flushIndex().catch(PASS)).toEqual();
Expand All @@ -260,12 +293,6 @@ describe('Elastic6Service', () => {
// expect2(await service.flushIndex().catch(GETERR)).toEqual(`404 NOT FOUND - index:${indexName}`);
// expect2(await service.describe().catch(GETERR)).toEqual(`404 NOT FOUND - index:${indexName}`);

//! make sure the index created
expect2(await service.createIndex().catch(PASS)).toEqual({ status: 200, acknowledged: true, index: indexName });
await waited(200);
// expect2(await service.createIndex().catch(PASS)).toEqual(`400 IN USE - index:${indexName}`);
expect2(await service.createIndex().catch(GETERR)).toEqual(`400 IN USE - index:${indexName}`);

//! for debugging.
// expect2(await service.readItem('A0').catch(PASS)).toEqual();
// expect2(await service.deleteItem('A0').catch(PASS)).toEqual();
Expand Down Expand Up @@ -295,7 +322,7 @@ describe('Elastic6Service', () => {
//! try to increment fields
//claire[6.2]: 버전이 7이하임에도 '400 ILLEGAL ARGUMENT - illegal_argument_exception'
expect2(await service.updateItem('A0', null, { count: 0 }).catch(GETERR)).toEqual(
service.version < 7 ? '400 INVALID FIELD - id:A0' : '400 ILLEGAL ARGUMENT - illegal_argument_exception',
'400 ILLEGAL ARGUMENT - illegal_argument_exception',
);
expect2(await service.updateItem('A0', { count: 0 }).catch(GETERR)).toEqual({
_id: 'A0',
Expand Down Expand Up @@ -405,11 +432,7 @@ describe('Elastic6Service', () => {
//! elastic storage service.
it('should pass basic CRUD w/ real server(6.2)', async () => {
// if (!PROFILE) return; // ignore w/o profile
//! load dummy storage service.
const { service, version } = instance('6.2');

//! check service identity
expect2(() => service.hello()).toEqual(`elastic6-service:test-v${version}:${version}`);
const { service } = await initService('6.2');

// skip test if some prerequisites are not satisfied
// 1. localhost is able to access elastic6 endpoint (by tunneling)
Expand Down Expand Up @@ -521,10 +544,10 @@ describe('Elastic6Service', () => {
it('should pass basic CRUD w/ real server(7.1)', async () => {
if (!PROFILE) return; // ignore w/o profile
//! load dummy storage service.
const { service, version } = instance('7.1');
const { service } = await initService('7.10');

//! check service identity
expect2(() => service.hello()).toEqual(`elastic6-service:test-v${version}:${version}`);
//! break if no live connection
if (!(await canPerformTest(service))) return;

// skip test if some prerequisites are not satisfied
// 1. localhost is able to access elastic6 endpoint (by tunneling)
Expand Down
25 changes: 18 additions & 7 deletions src/cores/elastic/elastic6-service.ts
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ export class Elastic6Service<T extends Elastic6Item = any> {
/**
* say hello of identity.
*/
public hello = () => `elastic6-service:${this.options.indexName}:${this.version}`;
public hello = () => `elastic6-service:${this.options.indexName}:${this.versionString}`;

/**
* get the client instance.
Expand All @@ -147,12 +147,22 @@ export class Elastic6Service<T extends Elastic6Item = any> {
return ver;
}

public get versionString(): string {
return this.options.version;
}

/**
* TODO - implement this w/ types @claire
*
*
* read the version text from root
*/
public async getVersion() {
public async getVersion(): Promise<string> {
const response = await this.client.transport.request({
method: 'GET',
path: '/',
});
const versionInfo: string = response.body.version.number;
claire-lemon marked this conversation as resolved.
Show resolved Hide resolved
return versionInfo;
}

/**
Expand Down Expand Up @@ -462,6 +472,7 @@ export class Elastic6Service<T extends Elastic6Item = any> {
$ERROR.handler('read', e => {
const msg = GETERR(e);
if (msg.startsWith('404 NOT FOUND')) throw new Error(`404 NOT FOUND - id:${id}`);
claire-lemon marked this conversation as resolved.
Show resolved Hide resolved
if (msg.startsWith('404 INDEX NOT FOUND')) throw new Error(`404 INDEX NOT FOUND - index:${indexName}`);
claire-lemon marked this conversation as resolved.
Show resolved Hide resolved
throw e;
}),
);
Expand Down Expand Up @@ -538,7 +549,7 @@ export class Elastic6Service<T extends Elastic6Item = any> {
L.push(`ctx._source.${key} += ${val}`);
return L;
}, []);
if (version < 7.0) params.body.lang = 'painless';
if (version < 6.8) params.body.lang = 'painless';
claire-lemon marked this conversation as resolved.
Show resolved Hide resolved
params.body.script = scripts.join('; ');
}
_log(NS, `> params[${id}] =`, $U.json(params));
Expand Down Expand Up @@ -765,19 +776,19 @@ export class Elastic6Service<T extends Elastic6Item = any> {
autocomplete_case_sensitive: {
type: 'custom',
tokenizer: 'edge_30grams',
filter: version < 7.0 ? ['standard'] : [], //! error - The [standard] token filter has been removed.
filter: version < 6.8 ? ['standard'] : [], //! error - The [standard] token filter has been removed.
},
},
},
},
//! since 7.x. no mapping for types.
mappings: version < 7.0 ? { [CONF_ES_DOCTYPE]: ES_MAPPINGS } : ES_MAPPINGS,
mappings: version < 6.8 ? { [CONF_ES_DOCTYPE]: ES_MAPPINGS } : ES_MAPPINGS,
};

//! timeseries 데이터로, 기본 timestamp 값을 넣어준다. (주의! save시 current-time 값 자동 저장)
if (!!CONF_ES_TIMESERIES) {
ES_SETTINGS.settings.refresh_interval = '5s';
if (version < 7.0) {
if (version < 6.8) {
ES_SETTINGS.mappings[CONF_ES_DOCTYPE].properties['@timestamp'] = { type: 'date', doc_values: true };
ES_SETTINGS.mappings[CONF_ES_DOCTYPE].properties['ip'] = { type: 'ip' };

Expand Down