sonamu 0.6.0 → 0.7.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.swcrc.project-default +18 -0
- package/bin/cli.js +24 -0
- package/dist/ai/agents/agent.d.ts +11 -0
- package/dist/ai/agents/agent.d.ts.map +1 -0
- package/dist/ai/agents/agent.js +65 -0
- package/dist/ai/agents/index.d.ts +3 -0
- package/dist/ai/agents/index.d.ts.map +1 -0
- package/dist/ai/agents/index.js +4 -0
- package/dist/ai/agents/types.d.ts +43 -0
- package/dist/ai/agents/types.d.ts.map +1 -0
- package/dist/ai/agents/types.js +3 -0
- package/dist/ai/index.d.ts +2 -0
- package/dist/ai/index.d.ts.map +1 -0
- package/dist/ai/index.js +3 -0
- package/dist/ai/providers/rtzr/api.d.ts +22 -0
- package/dist/ai/providers/rtzr/api.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/api.js +28 -0
- package/dist/ai/providers/rtzr/error.d.ts +18 -0
- package/dist/ai/providers/rtzr/error.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/error.js +29 -0
- package/dist/ai/providers/rtzr/index.d.ts +5 -0
- package/dist/ai/providers/rtzr/index.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/index.js +6 -0
- package/dist/ai/providers/rtzr/model.d.ts +52 -0
- package/dist/ai/providers/rtzr/model.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/model.js +137 -0
- package/dist/ai/providers/rtzr/options.d.ts +7 -0
- package/dist/ai/providers/rtzr/options.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/options.js +47 -0
- package/dist/ai/providers/rtzr/provider.d.ts +18 -0
- package/dist/ai/providers/rtzr/provider.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/provider.js +54 -0
- package/dist/ai/providers/rtzr/utils.d.ts +19 -0
- package/dist/ai/providers/rtzr/utils.d.ts.map +1 -0
- package/dist/ai/providers/rtzr/utils.js +88 -0
- package/dist/api/base-frame.d.ts +2 -2
- package/dist/api/base-frame.d.ts.map +1 -1
- package/dist/api/base-frame.js +2 -1
- package/dist/api/caster.d.ts.map +1 -1
- package/dist/api/caster.js +6 -1
- package/dist/api/code-converters.d.ts +58 -14
- package/dist/api/code-converters.d.ts.map +1 -1
- package/dist/api/code-converters.js +178 -409
- package/dist/api/config.d.ts +27 -13
- package/dist/api/config.d.ts.map +1 -1
- package/dist/api/config.js +19 -26
- package/dist/api/context.d.ts +4 -3
- package/dist/api/context.d.ts.map +1 -1
- package/dist/api/context.js +1 -1
- package/dist/api/decorators.d.ts +20 -6
- package/dist/api/decorators.d.ts.map +1 -1
- package/dist/api/decorators.js +111 -18
- package/dist/api/index.d.ts +2 -2
- package/dist/api/index.d.ts.map +1 -1
- package/dist/api/index.js +3 -3
- package/dist/api/sonamu.d.ts +7 -7
- package/dist/api/sonamu.d.ts.map +1 -1
- package/dist/api/sonamu.js +83 -51
- package/dist/api/validator.d.ts +6 -0
- package/dist/api/validator.d.ts.map +1 -0
- package/dist/api/validator.js +81 -0
- package/dist/bin/build-config.d.ts +5 -1
- package/dist/bin/build-config.d.ts.map +1 -1
- package/dist/bin/build-config.js +5 -2
- package/dist/bin/cli.js +165 -64
- package/dist/bin/loader-register.d.ts +2 -0
- package/dist/bin/loader-register.d.ts.map +1 -0
- package/dist/bin/loader-register.js +34 -0
- package/dist/database/_batch_update.d.ts +5 -3
- package/dist/database/_batch_update.d.ts.map +1 -1
- package/dist/database/_batch_update.js +30 -13
- package/dist/database/base-model.d.ts +96 -10
- package/dist/database/base-model.d.ts.map +1 -1
- package/dist/database/base-model.js +232 -89
- package/dist/database/base-model.types.d.ts +93 -0
- package/dist/database/base-model.types.d.ts.map +1 -0
- package/dist/database/base-model.types.js +10 -0
- package/dist/database/code-generator.d.ts +1 -1
- package/dist/database/code-generator.d.ts.map +1 -1
- package/dist/database/code-generator.js +11 -10
- package/dist/database/db.d.ts +5 -6
- package/dist/database/db.d.ts.map +1 -1
- package/dist/database/db.js +22 -25
- package/dist/database/puri-subset.test-d.js +81 -0
- package/dist/database/puri-subset.types.d.ts +123 -0
- package/dist/database/puri-subset.types.d.ts.map +1 -0
- package/dist/database/puri-subset.types.js +16 -0
- package/dist/database/puri-wrapper.d.ts +13 -11
- package/dist/database/puri-wrapper.d.ts.map +1 -1
- package/dist/database/puri-wrapper.js +2 -2
- package/dist/database/puri.d.ts +25 -14
- package/dist/database/puri.d.ts.map +1 -1
- package/dist/database/puri.js +83 -21
- package/dist/database/puri.types.d.ts +21 -7
- package/dist/database/puri.types.d.ts.map +1 -1
- package/dist/database/puri.types.js +4 -1
- package/dist/database/transaction-context.d.ts +1 -1
- package/dist/database/transaction-context.d.ts.map +1 -1
- package/dist/database/transaction-context.js +1 -1
- package/dist/database/upsert-builder.d.ts +9 -3
- package/dist/database/upsert-builder.d.ts.map +1 -1
- package/dist/database/upsert-builder.js +227 -78
- package/dist/entity/entity-manager.d.ts +165 -2
- package/dist/entity/entity-manager.d.ts.map +1 -1
- package/dist/entity/entity-manager.js +26 -10
- package/dist/entity/entity.d.ts +5 -3
- package/dist/entity/entity.d.ts.map +1 -1
- package/dist/entity/entity.js +153 -54
- package/dist/exceptions/error-handler.d.ts +1 -1
- package/dist/exceptions/error-handler.d.ts.map +1 -1
- package/dist/exceptions/error-handler.js +1 -1
- package/dist/exceptions/so-exceptions.d.ts +1 -1
- package/dist/exceptions/so-exceptions.d.ts.map +1 -1
- package/dist/exceptions/so-exceptions.js +1 -1
- package/dist/file-storage/driver.d.ts +1 -1
- package/dist/file-storage/driver.d.ts.map +1 -1
- package/dist/file-storage/driver.js +1 -1
- package/dist/file-storage/file-storage.js +2 -2
- package/dist/index.d.ts +18 -11
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +19 -13
- package/dist/migration/code-generation.d.ts +1 -1
- package/dist/migration/code-generation.d.ts.map +1 -1
- package/dist/migration/code-generation.js +123 -67
- package/dist/migration/migration-set.d.ts +2 -10
- package/dist/migration/migration-set.d.ts.map +1 -1
- package/dist/migration/migration-set.js +67 -218
- package/dist/migration/migrator.d.ts +24 -73
- package/dist/migration/migrator.d.ts.map +1 -1
- package/dist/migration/migrator.js +121 -301
- package/dist/migration/postgresql-schema-reader.d.ts +51 -0
- package/dist/migration/postgresql-schema-reader.d.ts.map +1 -0
- package/dist/migration/postgresql-schema-reader.js +245 -0
- package/dist/migration/types.d.ts +6 -38
- package/dist/migration/types.d.ts.map +1 -1
- package/dist/migration/types.js +1 -1
- package/dist/naite/messaging-types.d.ts +43 -0
- package/dist/naite/messaging-types.d.ts.map +1 -0
- package/dist/naite/messaging-types.js +7 -0
- package/dist/naite/naite-reporter.d.ts +41 -0
- package/dist/naite/naite-reporter.d.ts.map +1 -0
- package/dist/naite/naite-reporter.js +102 -0
- package/dist/naite/naite.d.ts +91 -8
- package/dist/naite/naite.d.ts.map +1 -1
- package/dist/naite/naite.js +285 -41
- package/dist/stream/sse.d.ts +2 -2
- package/dist/stream/sse.d.ts.map +1 -1
- package/dist/stream/sse.js +1 -1
- package/dist/syncer/api-parser.d.ts +3 -13
- package/dist/syncer/api-parser.d.ts.map +1 -1
- package/dist/syncer/api-parser.js +67 -56
- package/dist/syncer/checksum.d.ts +2 -2
- package/dist/syncer/checksum.d.ts.map +1 -1
- package/dist/syncer/checksum.js +11 -11
- package/dist/syncer/code-generator.d.ts +3 -3
- package/dist/syncer/code-generator.d.ts.map +1 -1
- package/dist/syncer/code-generator.js +37 -17
- package/dist/syncer/entity-operations.d.ts +2 -2
- package/dist/syncer/entity-operations.d.ts.map +1 -1
- package/dist/syncer/entity-operations.js +9 -8
- package/dist/syncer/file-patterns.d.ts +1 -1
- package/dist/syncer/file-patterns.d.ts.map +1 -1
- package/dist/syncer/file-patterns.js +1 -1
- package/dist/syncer/index.d.ts +4 -4
- package/dist/syncer/index.d.ts.map +1 -1
- package/dist/syncer/index.js +5 -5
- package/dist/syncer/module-loader.d.ts +4 -4
- package/dist/syncer/module-loader.d.ts.map +1 -1
- package/dist/syncer/module-loader.js +17 -12
- package/dist/syncer/syncer.d.ts +31 -24
- package/dist/syncer/syncer.d.ts.map +1 -1
- package/dist/syncer/syncer.js +92 -45
- package/dist/template/entity-converter.d.ts +1 -1
- package/dist/template/entity-converter.d.ts.map +1 -1
- package/dist/template/entity-converter.js +15 -8
- package/dist/template/helpers.d.ts +2 -2
- package/dist/template/helpers.d.ts.map +1 -1
- package/dist/template/helpers.js +3 -3
- package/dist/template/implementations/entity.template.d.ts +2 -2
- package/dist/template/implementations/entity.template.d.ts.map +1 -1
- package/dist/template/implementations/entity.template.js +4 -5
- package/dist/template/implementations/generated.template.d.ts +2 -3
- package/dist/template/implementations/generated.template.d.ts.map +1 -1
- package/dist/template/implementations/generated.template.js +46 -29
- package/dist/template/implementations/generated_http.template.d.ts +2 -3
- package/dist/template/implementations/generated_http.template.d.ts.map +1 -1
- package/dist/template/implementations/generated_http.template.js +9 -9
- package/dist/template/implementations/generated_sso.template.d.ts +3 -4
- package/dist/template/implementations/generated_sso.template.d.ts.map +1 -1
- package/dist/template/implementations/generated_sso.template.js +54 -25
- package/dist/template/implementations/init_types.template.d.ts +2 -2
- package/dist/template/implementations/init_types.template.d.ts.map +1 -1
- package/dist/template/implementations/init_types.template.js +2 -2
- package/dist/template/implementations/model.template.d.ts +2 -2
- package/dist/template/implementations/model.template.d.ts.map +1 -1
- package/dist/template/implementations/model.template.js +47 -37
- package/dist/template/implementations/model_test.template.d.ts +2 -2
- package/dist/template/implementations/model_test.template.d.ts.map +1 -1
- package/dist/template/implementations/model_test.template.js +2 -2
- package/dist/template/implementations/service.template.d.ts +4 -4
- package/dist/template/implementations/service.template.d.ts.map +1 -1
- package/dist/template/implementations/service.template.js +24 -16
- package/dist/template/implementations/view_enums_buttonset.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_buttonset.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_buttonset.template.js +1 -1
- package/dist/template/implementations/view_enums_dropdown.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_dropdown.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_dropdown.template.js +2 -2
- package/dist/template/implementations/view_enums_select.template.d.ts +2 -2
- package/dist/template/implementations/view_enums_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_enums_select.template.js +2 -2
- package/dist/template/implementations/view_form.template.d.ts +2 -2
- package/dist/template/implementations/view_form.template.d.ts.map +1 -1
- package/dist/template/implementations/view_form.template.js +4 -4
- package/dist/template/implementations/view_id_all_select.template.d.ts +2 -2
- package/dist/template/implementations/view_id_all_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_id_all_select.template.js +1 -1
- package/dist/template/implementations/view_id_async_select.template.d.ts +2 -2
- package/dist/template/implementations/view_id_async_select.template.d.ts.map +1 -1
- package/dist/template/implementations/view_id_async_select.template.js +1 -1
- package/dist/template/implementations/view_list.template.d.ts +2 -2
- package/dist/template/implementations/view_list.template.d.ts.map +1 -1
- package/dist/template/implementations/view_list.template.js +29 -19
- package/dist/template/implementations/view_list_columns.template.d.ts +3 -3
- package/dist/template/implementations/view_list_columns.template.d.ts.map +1 -1
- package/dist/template/implementations/view_list_columns.template.js +1 -1
- package/dist/template/implementations/view_search_input.template.d.ts +2 -2
- package/dist/template/implementations/view_search_input.template.d.ts.map +1 -1
- package/dist/template/implementations/view_search_input.template.js +1 -1
- package/dist/template/index.d.ts +4 -2
- package/dist/template/index.d.ts.map +1 -1
- package/dist/template/index.js +5 -3
- package/dist/template/template-manager.d.ts +56 -0
- package/dist/template/template-manager.d.ts.map +1 -0
- package/dist/template/template-manager.js +125 -0
- package/dist/template/template-types.d.ts +16 -0
- package/dist/template/template-types.d.ts.map +1 -0
- package/dist/template/template-types.js +7 -0
- package/dist/template/template.d.ts +12 -2
- package/dist/template/template.d.ts.map +1 -1
- package/dist/template/template.js +19 -6
- package/dist/template/zod-converter.d.ts +40 -7
- package/dist/template/zod-converter.d.ts.map +1 -1
- package/dist/template/zod-converter.js +386 -58
- package/dist/testing/_relation-graph.d.ts +1 -1
- package/dist/testing/_relation-graph.d.ts.map +1 -1
- package/dist/testing/_relation-graph.js +12 -3
- package/dist/testing/fixture-manager.d.ts +42 -11
- package/dist/testing/fixture-manager.d.ts.map +1 -1
- package/dist/testing/fixture-manager.js +338 -236
- package/dist/types/types.d.ts +709 -104
- package/dist/types/types.d.ts.map +1 -1
- package/dist/types/types.js +309 -52
- package/dist/typings/knex.d.js +2 -2
- package/dist/utils/async-utils.d.ts.map +1 -1
- package/dist/utils/async-utils.js +3 -3
- package/dist/utils/console-util.js +1 -1
- package/dist/utils/controller.d.ts +1 -0
- package/dist/utils/controller.d.ts.map +1 -1
- package/dist/utils/controller.js +4 -1
- package/dist/utils/esm-utils.d.ts +0 -6
- package/dist/utils/esm-utils.d.ts.map +1 -1
- package/dist/utils/esm-utils.js +2 -9
- package/dist/utils/formatter.d.ts +3 -0
- package/dist/utils/formatter.d.ts.map +1 -0
- package/dist/utils/formatter.js +110 -0
- package/dist/utils/fs-utils.d.ts +1 -1
- package/dist/utils/fs-utils.d.ts.map +1 -1
- package/dist/utils/fs-utils.js +1 -1
- package/dist/utils/lodash-able.d.ts.map +1 -1
- package/dist/utils/lodash-able.js +1 -1
- package/dist/utils/object-utils.d.ts +44 -0
- package/dist/utils/object-utils.d.ts.map +1 -0
- package/dist/utils/object-utils.js +191 -0
- package/dist/utils/path-utils.d.ts +1 -1
- package/dist/utils/path-utils.d.ts.map +1 -1
- package/dist/utils/path-utils.js +3 -3
- package/dist/utils/process-utils.js +1 -1
- package/dist/utils/sql-parser.d.ts +5 -1
- package/dist/utils/sql-parser.d.ts.map +1 -1
- package/dist/utils/sql-parser.js +14 -3
- package/dist/utils/type-utils.d.ts +23 -0
- package/dist/utils/type-utils.d.ts.map +1 -0
- package/dist/utils/type-utils.js +45 -0
- package/dist/utils/utils.d.ts +7 -1
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +44 -5
- package/dist/utils/zod-error.d.ts +1 -1
- package/dist/utils/zod-error.d.ts.map +1 -1
- package/dist/utils/zod-error.js +1 -1
- package/package.json +55 -30
- package/src/ai/agents/agent.ts +87 -0
- package/src/ai/agents/index.ts +2 -0
- package/src/ai/agents/types.ts +47 -0
- package/src/ai/index.ts +1 -0
- package/src/ai/providers/rtzr/api.ts +37 -0
- package/src/ai/providers/rtzr/error.ts +34 -0
- package/src/ai/providers/rtzr/index.ts +4 -0
- package/src/ai/providers/rtzr/model.ts +201 -0
- package/src/ai/providers/rtzr/options.ts +49 -0
- package/src/ai/providers/rtzr/provider.ts +91 -0
- package/src/ai/providers/rtzr/utils.ts +127 -0
- package/src/api/base-frame.ts +4 -2
- package/src/api/caster.ts +17 -23
- package/src/api/code-converters.ts +176 -533
- package/src/api/config.ts +39 -56
- package/src/api/context.ts +7 -18
- package/src/api/decorators.ts +175 -46
- package/src/api/index.ts +2 -2
- package/src/api/sonamu.ts +133 -124
- package/src/api/validator.ts +83 -0
- package/src/bin/build-config.ts +7 -1
- package/src/bin/cli.ts +192 -110
- package/src/bin/loader-register.ts +38 -0
- package/src/database/_batch_update.ts +46 -31
- package/src/database/base-model.ts +390 -182
- package/src/database/base-model.types.ts +155 -0
- package/src/database/code-generator.ts +13 -32
- package/src/database/db.ts +36 -50
- package/src/database/puri-subset.test-d.ts +471 -0
- package/src/database/puri-subset.types.ts +195 -0
- package/src/database/puri-wrapper.ts +58 -67
- package/src/database/puri.ts +182 -126
- package/src/database/puri.types.ts +64 -31
- package/src/database/transaction-context.ts +1 -1
- package/src/database/upsert-builder.ts +261 -132
- package/src/entity/entity-manager.ts +36 -28
- package/src/entity/entity.ts +330 -249
- package/src/exceptions/error-handler.ts +3 -3
- package/src/exceptions/so-exceptions.ts +11 -11
- package/src/file-storage/driver.ts +5 -5
- package/src/file-storage/file-storage.ts +2 -2
- package/src/index.ts +18 -12
- package/src/migration/code-generation.ts +185 -172
- package/src/migration/migration-set.ts +80 -293
- package/src/migration/migrator.ts +182 -425
- package/src/migration/mysql-schema-reader.ts.txt +272 -0
- package/src/migration/postgresql-schema-reader.ts +310 -0
- package/src/migration/types.ts +6 -39
- package/src/naite/messaging-types.ts +51 -0
- package/src/naite/naite-reporter.ts +128 -0
- package/src/naite/naite.ts +378 -33
- package/src/shared/web.shared.ts.txt +20 -24
- package/src/stream/sse.ts +5 -5
- package/src/syncer/api-parser.ts +52 -69
- package/src/syncer/checksum.ts +25 -37
- package/src/syncer/code-generator.ts +58 -62
- package/src/syncer/entity-operations.ts +12 -15
- package/src/syncer/file-patterns.ts +2 -2
- package/src/syncer/index.ts +4 -4
- package/src/syncer/module-loader.ts +28 -25
- package/src/syncer/syncer.ts +155 -162
- package/src/template/entity-converter.ts +18 -27
- package/src/template/helpers.ts +8 -11
- package/src/template/implementations/entity.template.ts +6 -6
- package/src/template/implementations/generated.template.ts +99 -99
- package/src/template/implementations/generated_http.template.ts +21 -54
- package/src/template/implementations/generated_sso.template.ts +78 -65
- package/src/template/implementations/init_types.template.ts +4 -6
- package/src/template/implementations/model.template.ts +47 -38
- package/src/template/implementations/model_test.template.ts +3 -3
- package/src/template/implementations/service.template.ts +56 -80
- package/src/template/implementations/view_enums_buttonset.template.ts +2 -2
- package/src/template/implementations/view_enums_dropdown.template.ts +4 -4
- package/src/template/implementations/view_enums_select.template.ts +3 -3
- package/src/template/implementations/view_form.template.ts +34 -75
- package/src/template/implementations/view_id_all_select.template.ts +2 -2
- package/src/template/implementations/view_id_async_select.template.ts +9 -23
- package/src/template/implementations/view_list.template.ts +54 -95
- package/src/template/implementations/view_list_columns.template.ts +4 -10
- package/src/template/implementations/view_search_input.template.ts +2 -2
- package/src/template/index.ts +4 -2
- package/src/template/template-manager.ts +166 -0
- package/src/template/template-types.ts +16 -0
- package/src/template/template.ts +29 -10
- package/src/template/zod-converter.ts +459 -101
- package/src/testing/_relation-graph.ts +18 -11
- package/src/testing/fixture-manager.ts +468 -362
- package/src/types/types.ts +516 -248
- package/src/typings/knex.d.ts +7 -9
- package/src/utils/async-utils.ts +8 -12
- package/src/utils/console-util.ts +1 -1
- package/src/utils/controller.ts +3 -0
- package/src/utils/esm-utils.ts +8 -18
- package/src/utils/formatter.ts +109 -0
- package/src/utils/fs-utils.ts +1 -1
- package/src/utils/lodash-able.ts +1 -4
- package/src/utils/object-utils.ts +217 -0
- package/src/utils/path-utils.ts +3 -6
- package/src/utils/process-utils.ts +1 -1
- package/src/utils/sql-parser.ts +23 -5
- package/src/utils/type-utils.ts +83 -0
- package/src/utils/utils.ts +58 -9
- package/src/utils/zod-error.ts +3 -3
- package/dist/bin/cli-wrapper.d.ts +0 -3
- package/dist/bin/cli-wrapper.d.ts.map +0 -1
- package/dist/bin/cli-wrapper.js +0 -72
- package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts +0 -2
- package/dist/database/knex-plugins/knex-on-duplicate-update.d.ts.map +0 -1
- package/dist/database/knex-plugins/knex-on-duplicate-update.js +0 -39
- package/dist/entity/entity-utils.d.ts +0 -61
- package/dist/entity/entity-utils.d.ts.map +0 -1
- package/dist/entity/entity-utils.js +0 -210
- package/src/bin/cli-wrapper.ts +0 -82
- package/src/database/knex-plugins/knex-on-duplicate-update.ts +0 -45
- package/src/entity/entity-utils.ts +0 -291
package/dist/naite/naite.d.ts
CHANGED
|
@@ -1,12 +1,95 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
/** biome-ignore-all lint/suspicious/noExplicitAny: Naite는 expect와 호응하도록 any를 허용함 */
|
|
2
|
+
import type { ComparisonOperator } from "../database/puri.types";
|
|
3
|
+
interface StackFrame {
|
|
4
|
+
functionName: string | null;
|
|
5
|
+
filePath: string;
|
|
6
|
+
lineNumber: number;
|
|
7
|
+
}
|
|
8
|
+
interface NaiteTrace {
|
|
9
|
+
key: string;
|
|
10
|
+
data: any;
|
|
11
|
+
stack: StackFrame[];
|
|
12
|
+
at: Date;
|
|
13
|
+
}
|
|
14
|
+
export type NaiteStore = Map<string, NaiteTrace[]>;
|
|
15
|
+
/**
|
|
16
|
+
* NaiteQuery 클래스
|
|
17
|
+
* 체이닝을 통한 trace 필터링 및 조회
|
|
18
|
+
*/
|
|
19
|
+
export declare class NaiteQuery {
|
|
20
|
+
private traces;
|
|
21
|
+
constructor(traces: NaiteTrace[]);
|
|
22
|
+
/**
|
|
23
|
+
* 파일명으로 필터링
|
|
24
|
+
* @param fileName 파일명 (예: "syncer.test.ts")
|
|
25
|
+
*/
|
|
26
|
+
fromFile(fileName: string): NaiteQuery;
|
|
27
|
+
/**
|
|
28
|
+
* 함수명으로 필터링
|
|
29
|
+
* @param funcName 함수명 (includes 체크)
|
|
30
|
+
* @param options.from 'direct' = 직접 호출만, 'indirect' = 간접 호출만, 'both' = 모두
|
|
31
|
+
*/
|
|
32
|
+
fromFunction(funcName: string, options?: {
|
|
33
|
+
from: "direct" | "indirect" | "both";
|
|
34
|
+
}): NaiteQuery;
|
|
35
|
+
/**
|
|
36
|
+
* 데이터 경로 기반 필터링
|
|
37
|
+
* @param path radash get 경로 (예: "data.userId")
|
|
38
|
+
* @param operator 비교 연산자
|
|
39
|
+
* @param value 비교값
|
|
40
|
+
*/
|
|
41
|
+
where(path: string, operator: ComparisonOperator | "includes", value: any): NaiteQuery;
|
|
42
|
+
/**
|
|
43
|
+
* 전체 데이터 배열 반환
|
|
44
|
+
*/
|
|
45
|
+
result(): any[];
|
|
46
|
+
/**
|
|
47
|
+
* 첫 번째 데이터 반환
|
|
48
|
+
*/
|
|
49
|
+
first(): any | undefined;
|
|
50
|
+
/**
|
|
51
|
+
* 마지막 데이터 반환
|
|
52
|
+
*/
|
|
53
|
+
last(): any | undefined;
|
|
54
|
+
/**
|
|
55
|
+
* n번째 데이터 반환
|
|
56
|
+
*/
|
|
57
|
+
at(index: number): any | undefined;
|
|
58
|
+
/**
|
|
59
|
+
* 원본 trace 배열 반환 (디버깅/NaiteViewer용)
|
|
60
|
+
*/
|
|
61
|
+
getTraces(): NaiteTrace[];
|
|
62
|
+
}
|
|
63
|
+
export declare class NaiteClass {
|
|
64
|
+
t(name: string, value: any): void;
|
|
65
|
+
/**
|
|
66
|
+
* key 또는 wildcard 패턴으로 trace 조회
|
|
67
|
+
* 항상 NaiteQuery 반환하여 체이닝 가능
|
|
68
|
+
*/
|
|
69
|
+
get(keyPattern: string): NaiteQuery;
|
|
70
|
+
getAll(): {
|
|
5
71
|
[key: string]: any;
|
|
6
72
|
};
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
73
|
+
/**
|
|
74
|
+
* 스토어에 들어있던 트레이스를 고대로 꺼내옵니다.
|
|
75
|
+
* 이때 값들은 모두 직렬화 가능한 상태로 나가게 됩니다.
|
|
76
|
+
* 테스트 정보와 함께 extensions에 보낼 용도로 만들었습니다.
|
|
77
|
+
* @returns
|
|
78
|
+
*/
|
|
79
|
+
getAllTraces(): {
|
|
80
|
+
key: string;
|
|
81
|
+
value: any;
|
|
82
|
+
filePath: string;
|
|
83
|
+
lineNumber: number;
|
|
84
|
+
at: string;
|
|
85
|
+
}[];
|
|
86
|
+
del(key: string): void;
|
|
87
|
+
createStore(): NaiteStore;
|
|
88
|
+
d(_message: string): void;
|
|
89
|
+
i(_message: string): void;
|
|
90
|
+
w(_message: string): void;
|
|
91
|
+
e(_message: string): void;
|
|
11
92
|
}
|
|
93
|
+
export declare const Naite: NaiteClass;
|
|
94
|
+
export {};
|
|
12
95
|
//# sourceMappingURL=naite.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"naite.d.ts","sourceRoot":"","sources":["../../src/naite/naite.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"naite.d.ts","sourceRoot":"","sources":["../../src/naite/naite.ts"],"names":[],"mappings":"AAAA,oFAAoF;AAIpF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAIjE,UAAU,UAAU;IAClB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB;AAGD,UAAU,UAAU;IAClB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,GAAG,CAAC;IACV,KAAK,EAAE,UAAU,EAAE,CAAC;IACpB,EAAE,EAAE,IAAI,CAAC;CACV;AAGD,MAAM,MAAM,UAAU,GAAG,GAAG,CAAC,MAAM,EAAE,UAAU,EAAE,CAAC,CAAC;AAsGnD;;;GAGG;AACH,qBAAa,UAAU;IACT,OAAO,CAAC,MAAM;gBAAN,MAAM,EAAE,UAAU,EAAE;IAExC;;;OAGG;IACH,QAAQ,CAAC,QAAQ,EAAE,MAAM,GAAG,UAAU;IAOtC;;;;OAIG;IACH,YAAY,CACV,QAAQ,EAAE,MAAM,EAChB,OAAO,GAAE;QAAE,IAAI,EAAE,QAAQ,GAAG,UAAU,GAAG,MAAM,CAAA;KAAqB,GACnE,UAAU;IAgBb;;;;;OAKG;IACH,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,kBAAkB,GAAG,UAAU,EAAE,KAAK,EAAE,GAAG,GAAG,UAAU;IA0BtF;;OAEG;IACH,MAAM,IAAI,GAAG,EAAE;IAIf;;OAEG;IACH,KAAK,IAAI,GAAG,GAAG,SAAS;IAIxB;;OAEG;IACH,IAAI,IAAI,GAAG,GAAG,SAAS;IAIvB;;OAEG;IACH,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG,GAAG,SAAS;IAIlC;;OAEG;IACH,SAAS,IAAI,UAAU,EAAE;CAG1B;AAGD,qBAAa,UAAU;IAErB,CAAC,CACC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,GAAG;IAmCZ;;;OAGG;IACH,GAAG,CAAC,UAAU,EAAE,MAAM,GAAG,UAAU;IA0BnC,MAAM,IAAI;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;KAAE;IAmBhC;;;;;OAKG;IACH,YAAY,IAAI;QACd,GAAG,EAAE,MAAM,CAAC;QACZ,KAAK,EAAE,GAAG,CAAC;QACX,QAAQ,EAAE,MAAM,CAAC;QACjB,UAAU,EAAE,MAAM,CAAC;QACnB,EAAE,EAAE,MAAM,CAAC;KACZ,EAAE;IA+CH,GAAG,CAAC,GAAG,EAAE,MAAM;IAQf,WAAW,IAAI,UAAU;IAKzB,CAAC,CAAC,QAAQ,EAAE,MAAM;IAIlB,CAAC,CAAC,QAAQ,EAAE,MAAM;IAIlB,CAAC,CAAC,QAAQ,EAAE,MAAM;IAIlB,CAAC,CAAC,QAAQ,EAAE,MAAM;CAInB;AAED,eAAO,MAAM,KAAK,YAAmB,CAAC"}
|
package/dist/naite/naite.js
CHANGED
|
@@ -1,72 +1,316 @@
|
|
|
1
|
+
/** biome-ignore-all lint/suspicious/noExplicitAny: Naite는 expect와 호응하도록 any를 허용함 */ import { get } from "radashi";
|
|
1
2
|
import { Sonamu } from "../api/sonamu.js";
|
|
2
|
-
|
|
3
|
+
import { isSerializable } from "../utils/object-utils.js";
|
|
4
|
+
/**
|
|
5
|
+
* 콜스택을 파싱하여 StackFrame 배열로 반환
|
|
6
|
+
* - extractCallStack 자신과 Naite.t는 제외
|
|
7
|
+
* - runWithContext/runWithMockContext 발견 시 거기서 종료
|
|
8
|
+
* - node: 내부 경로는 포함하되, lineNumber는 path에 : 포함 시 붙이지 않음
|
|
9
|
+
*/ function extractCallStack() {
|
|
10
|
+
const stack = new Error().stack;
|
|
11
|
+
if (!stack) return [];
|
|
12
|
+
const lines = stack.split("\n");
|
|
13
|
+
// 콜스택 구조:
|
|
14
|
+
// [0]: "Error"
|
|
15
|
+
// [1]: "at extractCallStack"
|
|
16
|
+
// [2]: "at Naite.t"
|
|
17
|
+
// [3]: 실제 호출 위치부터 시작
|
|
18
|
+
const frames = lines.slice(3).map(parseStackFrame).filter((frame)=>frame !== null);
|
|
19
|
+
// runWithContext 계열 함수 발견 시 거기서 자르기
|
|
20
|
+
const contextIndex = frames.findIndex((f)=>f.functionName?.includes("runWithContext") || f.functionName?.includes("runWithMockContext"));
|
|
21
|
+
return contextIndex >= 0 ? frames.slice(0, contextIndex + 1) : frames;
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* 콜스택 한 줄을 파싱
|
|
25
|
+
* 형식1: "at FunctionName (filePath:lineNumber:columnNumber)"
|
|
26
|
+
* 형식2: "at filePath:lineNumber:columnNumber" (익명 함수/모듈 레벨)
|
|
27
|
+
*/ function parseStackFrame(line) {
|
|
28
|
+
// 패턴1: "at FunctionName (filePath:lineNumber:columnNumber)"
|
|
29
|
+
const matchWithFunc = line.match(/at\s+(.+?)\s+\((.+?):(\d+):\d+\)/);
|
|
30
|
+
if (matchWithFunc) {
|
|
31
|
+
const functionName = matchWithFunc[1];
|
|
32
|
+
const filePath = matchWithFunc[2];
|
|
33
|
+
const lineNumberStr = matchWithFunc[3];
|
|
34
|
+
// filePath에 이미 :가 포함되어 있으면 (예: "node:internal/...")
|
|
35
|
+
if (filePath.includes(":")) {
|
|
36
|
+
return {
|
|
37
|
+
functionName,
|
|
38
|
+
filePath,
|
|
39
|
+
lineNumber: 0
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
return {
|
|
43
|
+
functionName,
|
|
44
|
+
filePath,
|
|
45
|
+
lineNumber: Number.parseInt(lineNumberStr, 10)
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
// 패턴2: "at filePath:lineNumber:columnNumber" (함수명 없음)
|
|
49
|
+
const matchNoFunc = line.match(/at\s+(.+?):(\d+):\d+$/);
|
|
50
|
+
if (matchNoFunc) {
|
|
51
|
+
const filePath = matchNoFunc[1];
|
|
52
|
+
const lineNumberStr = matchNoFunc[2];
|
|
53
|
+
return {
|
|
54
|
+
functionName: null,
|
|
55
|
+
filePath,
|
|
56
|
+
lineNumber: Number.parseInt(lineNumberStr, 10)
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
return null;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* wildcard 패턴 매칭
|
|
63
|
+
* 예시:
|
|
64
|
+
* - "syncer:*" → "syncer:a", "syncer:a:b" 모두 매칭
|
|
65
|
+
* - "syncer:*:user" → "syncer:renderTemplate:user" 매칭
|
|
66
|
+
* - "syncer:renderTemplate:*" → "syncer:renderTemplate:service" 매칭
|
|
67
|
+
*/ function matchesPattern(key, pattern) {
|
|
68
|
+
const keyParts = key.split(":");
|
|
69
|
+
const patternParts = pattern.split(":");
|
|
70
|
+
// 마지막이 * → prefix 매칭 (길이 무관)
|
|
71
|
+
// 예: "syncer:*"는 "syncer:a", "syncer:a:b" 모두 매칭
|
|
72
|
+
if (patternParts[patternParts.length - 1] === "*") {
|
|
73
|
+
const prefixParts = patternParts.slice(0, -1);
|
|
74
|
+
// prefix가 모두 일치하는지 확인
|
|
75
|
+
return prefixParts.every((part, i)=>part === keyParts[i]);
|
|
76
|
+
}
|
|
77
|
+
// 길이가 같아야 함
|
|
78
|
+
if (patternParts.length !== keyParts.length) {
|
|
79
|
+
return false;
|
|
80
|
+
}
|
|
81
|
+
// 각 파트가 * 또는 정확히 일치
|
|
82
|
+
return patternParts.every((part, i)=>part === "*" || part === keyParts[i]);
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* NaiteQuery 클래스
|
|
86
|
+
* 체이닝을 통한 trace 필터링 및 조회
|
|
87
|
+
*/ export class NaiteQuery {
|
|
88
|
+
traces;
|
|
89
|
+
constructor(traces){
|
|
90
|
+
this.traces = traces;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* 파일명으로 필터링
|
|
94
|
+
* @param fileName 파일명 (예: "syncer.test.ts")
|
|
95
|
+
*/ fromFile(fileName) {
|
|
96
|
+
const filtered = this.traces.filter((t)=>t.stack.some((frame)=>frame.filePath.endsWith(`/${fileName}`)));
|
|
97
|
+
return new NaiteQuery(filtered);
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* 함수명으로 필터링
|
|
101
|
+
* @param funcName 함수명 (includes 체크)
|
|
102
|
+
* @param options.from 'direct' = 직접 호출만, 'indirect' = 간접 호출만, 'both' = 모두
|
|
103
|
+
*/ fromFunction(funcName, options = {
|
|
104
|
+
from: "both"
|
|
105
|
+
}) {
|
|
106
|
+
const filtered = this.traces.filter((t)=>{
|
|
107
|
+
if (options.from === "direct") {
|
|
108
|
+
// stack[0]만 확인 (직접 호출)
|
|
109
|
+
return t.stack[0]?.functionName?.includes(funcName);
|
|
110
|
+
}
|
|
111
|
+
if (options.from === "indirect") {
|
|
112
|
+
// stack[1+]에서 확인 (간접 호출)
|
|
113
|
+
return t.stack.slice(1).some((f)=>f.functionName?.includes(funcName));
|
|
114
|
+
}
|
|
115
|
+
// 전체 스택에서 확인
|
|
116
|
+
return t.stack.some((f)=>f.functionName?.includes(funcName));
|
|
117
|
+
});
|
|
118
|
+
return new NaiteQuery(filtered);
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* 데이터 경로 기반 필터링
|
|
122
|
+
* @param path radash get 경로 (예: "data.userId")
|
|
123
|
+
* @param operator 비교 연산자
|
|
124
|
+
* @param value 비교값
|
|
125
|
+
*/ where(path, operator, value) {
|
|
126
|
+
const filtered = this.traces.filter((trace)=>{
|
|
127
|
+
const actual = get(trace, path);
|
|
128
|
+
switch(operator){
|
|
129
|
+
case ">":
|
|
130
|
+
return actual > value;
|
|
131
|
+
case "<":
|
|
132
|
+
return actual < value;
|
|
133
|
+
case ">=":
|
|
134
|
+
return actual >= value;
|
|
135
|
+
case "<=":
|
|
136
|
+
return actual <= value;
|
|
137
|
+
case "=":
|
|
138
|
+
return actual === value;
|
|
139
|
+
case "!=":
|
|
140
|
+
return actual !== value;
|
|
141
|
+
case "includes":
|
|
142
|
+
return typeof actual === "string" && actual.includes(value);
|
|
143
|
+
default:
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
return new NaiteQuery(filtered);
|
|
148
|
+
}
|
|
149
|
+
/**
|
|
150
|
+
* 전체 데이터 배열 반환
|
|
151
|
+
*/ result() {
|
|
152
|
+
return this.traces.map((t)=>t.data);
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* 첫 번째 데이터 반환
|
|
156
|
+
*/ first() {
|
|
157
|
+
return this.traces[0]?.data;
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* 마지막 데이터 반환
|
|
161
|
+
*/ last() {
|
|
162
|
+
return this.traces[this.traces.length - 1]?.data;
|
|
163
|
+
}
|
|
164
|
+
/**
|
|
165
|
+
* n번째 데이터 반환
|
|
166
|
+
*/ at(index) {
|
|
167
|
+
return this.traces[index]?.data;
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* 원본 trace 배열 반환 (디버깅/NaiteViewer용)
|
|
171
|
+
*/ getTraces() {
|
|
172
|
+
return this.traces;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
// Naite 싱글턴 객체 (추후 logger 연결 등의 상태 관리 필요성 고려)
|
|
176
|
+
export class NaiteClass {
|
|
3
177
|
// 테스트 로그 기록
|
|
4
|
-
|
|
178
|
+
t(name, value/*이렇게 받은 값이 NaiteTrace로 저장되어 있다가 추후에 vitest에게 meta를 통해 넘겨져 프로세스간 통신을 통해 직렬화되어야 하는 점을 고려하였을 때 여기에 Serializable을 써서 제한을 둘 수도 있지만, 사용상의 편의를 생각하여 any로 받습니다.*/ ) {
|
|
179
|
+
// 이 t 함수는 테스트 환경에서만 작동해야 합니다.
|
|
180
|
+
// 그리고 테스트 환경 판단에 왜 isTest() 함수를 사용하지 않았냐면요,,
|
|
181
|
+
// 이렇게 하는게 유틸 함수 불러와서 사용하는 것보다 조금이나마 빠를 것 같았기 때문입니다.
|
|
182
|
+
if (process.env.NODE_ENV !== "test") {
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
try {
|
|
186
|
+
const context = Sonamu.getContext();
|
|
187
|
+
const store = context?.naiteStore;
|
|
188
|
+
if (!store) {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
// 콜스택 수집
|
|
192
|
+
const stack = extractCallStack();
|
|
193
|
+
const trace = {
|
|
194
|
+
key: name,
|
|
195
|
+
data: value,
|
|
196
|
+
stack,
|
|
197
|
+
at: new Date()
|
|
198
|
+
};
|
|
199
|
+
// 항상 배열로 관리
|
|
200
|
+
const existing = store.get(name) ?? [];
|
|
201
|
+
store.set(name, [
|
|
202
|
+
...existing,
|
|
203
|
+
trace
|
|
204
|
+
]);
|
|
205
|
+
} catch {
|
|
206
|
+
// Context 없는 상황에서 Naite.t 호출
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* key 또는 wildcard 패턴으로 trace 조회
|
|
211
|
+
* 항상 NaiteQuery 반환하여 체이닝 가능
|
|
212
|
+
*/ get(keyPattern) {
|
|
5
213
|
const context = Sonamu.getContext();
|
|
6
214
|
const store = context?.naiteStore;
|
|
7
215
|
if (!store) {
|
|
8
|
-
return;
|
|
216
|
+
return new NaiteQuery([]);
|
|
217
|
+
}
|
|
218
|
+
// wildcard 없으면 exact match
|
|
219
|
+
if (!keyPattern.includes("*")) {
|
|
220
|
+
const traces = store.get(keyPattern) ?? [];
|
|
221
|
+
return new NaiteQuery(traces);
|
|
222
|
+
}
|
|
223
|
+
// wildcard 패턴 매칭
|
|
224
|
+
const allTraces = [];
|
|
225
|
+
for (const [key, traces] of store.entries()){
|
|
226
|
+
if (matchesPattern(key, keyPattern)) {
|
|
227
|
+
allTraces.push(...traces);
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
return new NaiteQuery(allTraces);
|
|
231
|
+
}
|
|
232
|
+
// 전체 리스트 가져오기
|
|
233
|
+
getAll() {
|
|
234
|
+
const context = Sonamu.getContext();
|
|
235
|
+
if (!context?.naiteStore) {
|
|
236
|
+
return {};
|
|
9
237
|
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
value
|
|
17
|
-
]);
|
|
238
|
+
// NaiteTrace 배열을 data만 추출하여 반환
|
|
239
|
+
const result = {};
|
|
240
|
+
for (const [key, traces] of context.naiteStore.entries()){
|
|
241
|
+
if (key.startsWith("mock:")) {
|
|
242
|
+
// Mock 설정은 그대로 반환
|
|
243
|
+
result[key] = traces;
|
|
18
244
|
} else {
|
|
19
|
-
//
|
|
20
|
-
|
|
21
|
-
store.get(name),
|
|
22
|
-
value
|
|
23
|
-
]);
|
|
245
|
+
// NaiteTrace 배열은 data만 추출
|
|
246
|
+
result[key] = traces.map((t)=>t.data);
|
|
24
247
|
}
|
|
25
|
-
} else {
|
|
26
|
-
// 값이 없는 경우 추가
|
|
27
|
-
store.set(name, value);
|
|
28
248
|
}
|
|
249
|
+
return result;
|
|
29
250
|
}
|
|
30
|
-
|
|
31
|
-
|
|
251
|
+
/**
|
|
252
|
+
* 스토어에 들어있던 트레이스를 고대로 꺼내옵니다.
|
|
253
|
+
* 이때 값들은 모두 직렬화 가능한 상태로 나가게 됩니다.
|
|
254
|
+
* 테스트 정보와 함께 extensions에 보낼 용도로 만들었습니다.
|
|
255
|
+
* @returns
|
|
256
|
+
*/ getAllTraces() {
|
|
32
257
|
const context = Sonamu.getContext();
|
|
33
|
-
if (!context?.naiteStore
|
|
34
|
-
|
|
258
|
+
if (!context?.naiteStore) {
|
|
259
|
+
return [];
|
|
260
|
+
}
|
|
261
|
+
const traces = Array.from(context.naiteStore.values()).flat();
|
|
262
|
+
// 직렬화 불가능한 값이 존재한다면 이를 대문짝만하게 알려줍니다! 그치만 알리기만 하고 그냥 지나갑니다 ㅎㅎ
|
|
263
|
+
// 왜 직렬화가 중요한가? 이(getAllTraces) 호출의 결과는 외부로 나가게 되는데,
|
|
264
|
+
// 이때 주 용도가 vitest의 task.meta 필드를 통해 afterEach에서 Sonamu extension으로 전달하는 것입니다.
|
|
265
|
+
// 여기서 meta 필드에 담긴 내용은 프로세스간 통신(process.send) 또는 스레드간 통신(message port)을 통해 전달되어야 하는데,
|
|
266
|
+
// 이로 인해 "직렬화 가능한 값들만 허용"하는 제약이 생깁니다.
|
|
267
|
+
//
|
|
268
|
+
// 이 제약을 의식하여 Naite.t에 직렬화 가능한 값만 넘기게 할 수도 있었지만, 그렇게 하면 불편해질 것 같아서 하지 않았습니다.
|
|
269
|
+
// 따라서 현재 Naite.t는 모든 값을 받을 수 있게 되어 있습니다.
|
|
270
|
+
// 대신 이렇게(getAllTraces) 그 값들을 빼낼 때 JSON.stringify를 사용하여 강제로 직렬화 가능하게 만들었습니다,,
|
|
271
|
+
for (const trace of traces){
|
|
272
|
+
const check = isSerializable(trace.data);
|
|
273
|
+
if (!check.valid) {
|
|
274
|
+
console.warn("\n" + "╔════════════════════════════════════════════════════════════════╗\n" + "║ [Naite] Non-serializable value detected! ║\n" + "╠════════════════════════════════════════════════════════════════╣\n" + `║ Key: ${trace.key.padEnd(57)}║\n` + `║ Reason: ${(check.reason ?? "unknown").slice(0, 54).padEnd(54)}║\n` + `║ Location: ${(trace.stack[0]?.filePath ?? "unknown").slice(-51).padEnd(52)}║\n` + `║ Line: ${String(trace.stack[0]?.lineNumber ?? 0).padEnd(56)}║\n` + "╠════════════════════════════════════════════════════════════════╣\n" + "║ Naite.t() accepts any type of value. However, values will ║\n" + "║ be serialized to JSON when exported via Naite.getAllTraces(). ║\n" + "╚════════════════════════════════════════════════════════════════╝\n");
|
|
275
|
+
}
|
|
35
276
|
}
|
|
36
|
-
return
|
|
277
|
+
return traces.map((trace)=>({
|
|
278
|
+
key: trace.key,
|
|
279
|
+
value: JSON.parse(JSON.stringify(trace.data ?? "")),
|
|
280
|
+
filePath: trace.stack[0]?.filePath ?? "",
|
|
281
|
+
lineNumber: trace.stack[0]?.lineNumber ?? 0,
|
|
282
|
+
at: trace.at.toISOString()
|
|
283
|
+
}));
|
|
37
284
|
}
|
|
38
|
-
//
|
|
39
|
-
|
|
285
|
+
// 특정 키 삭제하기
|
|
286
|
+
del(key) {
|
|
40
287
|
const context = Sonamu.getContext();
|
|
41
288
|
if (!context?.naiteStore) {
|
|
42
|
-
return
|
|
289
|
+
return;
|
|
43
290
|
}
|
|
44
|
-
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
// throw new Error("Vitest is not initialized");
|
|
50
|
-
// }
|
|
51
|
-
// return this.vitestExpect(this.get(name));
|
|
52
|
-
// }
|
|
291
|
+
context.naiteStore.delete(key);
|
|
292
|
+
}
|
|
293
|
+
createStore() {
|
|
294
|
+
return new Map();
|
|
295
|
+
}
|
|
53
296
|
// 일반 로그 레벨
|
|
54
|
-
|
|
297
|
+
d(_message) {
|
|
55
298
|
// TODO: Logger 연결
|
|
56
299
|
console.log(`[DEBUG] ${_message}`);
|
|
57
300
|
}
|
|
58
|
-
|
|
301
|
+
i(_message) {
|
|
59
302
|
// TODO: Logger 연결
|
|
60
303
|
console.log(`[INFO] ${_message}`);
|
|
61
304
|
}
|
|
62
|
-
|
|
305
|
+
w(_message) {
|
|
63
306
|
// TODO: Logger 연결
|
|
64
307
|
console.log(`[WARN] ${_message}`);
|
|
65
308
|
}
|
|
66
|
-
|
|
309
|
+
e(_message) {
|
|
67
310
|
// TODO: Logger 연결
|
|
68
311
|
console.log(`[ERROR] ${_message}`);
|
|
69
312
|
}
|
|
70
313
|
}
|
|
314
|
+
export const Naite = new NaiteClass();
|
|
71
315
|
|
|
72
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9uYWl0ZS9uYWl0ZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBTb25hbXUgfSBmcm9tIFwiLi4vYXBpL3NvbmFtdVwiO1xuXG5leHBvcnQgY2xhc3MgTmFpdGUge1xuICAvLyDthYzsiqTtirgg66Gc6re4IOq4sOuhnVxuICBzdGF0aWMgdChuYW1lOiBzdHJpbmcsIHZhbHVlOiBhbnkpIHtcbiAgICBjb25zdCBjb250ZXh0ID0gU29uYW11LmdldENvbnRleHQoKTtcbiAgICBjb25zdCBzdG9yZSA9IGNvbnRleHQ/Lm5haXRlU3RvcmU7XG5cbiAgICBpZiAoIXN0b3JlKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmIChzdG9yZS5oYXMobmFtZSkpIHtcbiAgICAgIC8vIOydtOuvuCDqsJLsnbQg7J6I64qUIOqyveyasFxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc3RvcmUuZ2V0KG5hbWUpKSkge1xuICAgICAgICAvLyDrsLDsl7Tsl5Ag7LaU6rCAXG4gICAgICAgIHN0b3JlLnNldChuYW1lLCBbLi4uc3RvcmUuZ2V0KG5hbWUpLCB2YWx1ZV0pO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgLy8g67Cw7Je07J20IOyVhOuLjCDqsr3smrAg67Cw7Je066GcIOuzgO2ZmFxuICAgICAgICBzdG9yZS5zZXQobmFtZSwgW3N0b3JlLmdldChuYW1lKSwgdmFsdWVdKTtcbiAgICAgIH1cbiAgICB9IGVsc2Uge1xuICAgICAgLy8g6rCS7J20IOyXhuuKlCDqsr3smrAg7LaU6rCAXG4gICAgICBzdG9yZS5zZXQobmFtZSwgdmFsdWUpO1xuICAgIH1cbiAgfVxuXG4gIC8vIO2FjOyKpO2KuOyXkOyEnCDqsJIg6rCA7KC47Jik6riwXG4gIHN0YXRpYyBnZXQobmFtZTogc3RyaW5nKTogYW55IHtcbiAgICBjb25zdCBjb250ZXh0ID0gU29uYW11LmdldENvbnRleHQoKTtcbiAgICBpZiAoIWNvbnRleHQ/Lm5haXRlU3RvcmUgfHwgIWNvbnRleHQubmFpdGVTdG9yZS5oYXMobmFtZSkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgTmFpdGUuZ2V0OiBcXGAke25hbWV9XFxgIG5vdCBmb3VuZGApO1xuICAgIH1cbiAgICByZXR1cm4gY29udGV4dD8ubmFpdGVTdG9yZT8uZ2V0KG5hbWUpO1xuICB9XG5cbiAgLy8g7KCE7LK0IOumrOyKpO2KuCDqsIDsoLjsmKTquLBcbiAgc3RhdGljIGdldEFsbCgpOiB7IFtrZXk6IHN0cmluZ106IGFueSB9IHtcbiAgICBjb25zdCBjb250ZXh0ID0gU29uYW11LmdldENvbnRleHQoKTtcbiAgICBpZiAoIWNvbnRleHQ/Lm5haXRlU3RvcmUpIHtcbiAgICAgIHJldHVybiB7fTtcbiAgICB9XG4gICAgcmV0dXJuIE9iamVjdC5mcm9tRW50cmllcyhjb250ZXh0Lm5haXRlU3RvcmUuZW50cmllcygpKTtcbiAgfVxuXG4gIC8vIGV4cGVjdCDrnpjtjbwgKENKUy1FU00g7J207IqI66GcIO2YhOyerCDsgqzsmqnrtojqsIApXG4gIC8vIHN0YXRpYyBleHBlY3QobmFtZTogc3RyaW5nKSB7XG4gIC8vICAgaWYgKCF0aGlzLnZpdGVzdEV4cGVjdCkge1xuICAvLyAgICAgdGhyb3cgbmV3IEVycm9yKFwiVml0ZXN0IGlzIG5vdCBpbml0aWFsaXplZFwiKTtcbiAgLy8gICB9XG4gIC8vICAgcmV0dXJuIHRoaXMudml0ZXN0RXhwZWN0KHRoaXMuZ2V0KG5hbWUpKTtcbiAgLy8gfVxuXG4gIC8vIOydvOuwmCDroZzqt7gg66CI67KoXG4gIHN0YXRpYyBkKF9tZXNzYWdlOiBzdHJpbmcpIHtcbiAgICAvLyBUT0RPOiBMb2dnZXIg7Jew6rKwXG4gICAgY29uc29sZS5sb2coYFtERUJVR10gJHtfbWVzc2FnZX1gKTtcbiAgfVxuICBzdGF0aWMgaShfbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgLy8gVE9ETzogTG9nZ2VyIOyXsOqysFxuICAgIGNvbnNvbGUubG9nKGBbSU5GT10gJHtfbWVzc2FnZX1gKTtcbiAgfVxuICBzdGF0aWMgdyhfbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgLy8gVE9ETzogTG9nZ2VyIOyXsOqysFxuICAgIGNvbnNvbGUubG9nKGBbV0FSTl0gJHtfbWVzc2FnZX1gKTtcbiAgfVxuICBzdGF0aWMgZShfbWVzc2FnZTogc3RyaW5nKSB7XG4gICAgLy8gVE9ETzogTG9nZ2VyIOyXsOqysFxuICAgIGNvbnNvbGUubG9nKGBbRVJST1JdICR7X21lc3NhZ2V9YCk7XG4gIH1cbn1cbiJdLCJuYW1lcyI6WyJTb25hbXUiLCJOYWl0ZSIsInQiLCJuYW1lIiwidmFsdWUiLCJjb250ZXh0IiwiZ2V0Q29udGV4dCIsInN0b3JlIiwibmFpdGVTdG9yZSIsImhhcyIsIkFycmF5IiwiaXNBcnJheSIsImdldCIsInNldCIsIkVycm9yIiwiZ2V0QWxsIiwiT2JqZWN0IiwiZnJvbUVudHJpZXMiLCJlbnRyaWVzIiwiZCIsIl9tZXNzYWdlIiwiY29uc29sZSIsImxvZyIsImkiLCJ3IiwiZSJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0EsTUFBTSxRQUFRLG1CQUFnQjtBQUV2QyxPQUFPLE1BQU1DO0lBQ1gsWUFBWTtJQUNaLE9BQU9DLEVBQUVDLElBQVksRUFBRUMsS0FBVSxFQUFFO1FBQ2pDLE1BQU1DLFVBQVVMLE9BQU9NLFVBQVU7UUFDakMsTUFBTUMsUUFBUUYsU0FBU0c7UUFFdkIsSUFBSSxDQUFDRCxPQUFPO1lBQ1Y7UUFDRjtRQUNBLElBQUlBLE1BQU1FLEdBQUcsQ0FBQ04sT0FBTztZQUNuQixjQUFjO1lBQ2QsSUFBSU8sTUFBTUMsT0FBTyxDQUFDSixNQUFNSyxHQUFHLENBQUNULFFBQVE7Z0JBQ2xDLFNBQVM7Z0JBQ1RJLE1BQU1NLEdBQUcsQ0FBQ1YsTUFBTTt1QkFBSUksTUFBTUssR0FBRyxDQUFDVDtvQkFBT0M7aUJBQU07WUFDN0MsT0FBTztnQkFDTCxtQkFBbUI7Z0JBQ25CRyxNQUFNTSxHQUFHLENBQUNWLE1BQU07b0JBQUNJLE1BQU1LLEdBQUcsQ0FBQ1Q7b0JBQU9DO2lCQUFNO1lBQzFDO1FBQ0YsT0FBTztZQUNMLGNBQWM7WUFDZEcsTUFBTU0sR0FBRyxDQUFDVixNQUFNQztRQUNsQjtJQUNGO0lBRUEsZUFBZTtJQUNmLE9BQU9RLElBQUlULElBQVksRUFBTztRQUM1QixNQUFNRSxVQUFVTCxPQUFPTSxVQUFVO1FBQ2pDLElBQUksQ0FBQ0QsU0FBU0csY0FBYyxDQUFDSCxRQUFRRyxVQUFVLENBQUNDLEdBQUcsQ0FBQ04sT0FBTztZQUN6RCxNQUFNLElBQUlXLE1BQU0sQ0FBQyxhQUFhLEVBQUVYLEtBQUssWUFBWSxDQUFDO1FBQ3BEO1FBQ0EsT0FBT0UsU0FBU0csWUFBWUksSUFBSVQ7SUFDbEM7SUFFQSxjQUFjO0lBQ2QsT0FBT1ksU0FBaUM7UUFDdEMsTUFBTVYsVUFBVUwsT0FBT00sVUFBVTtRQUNqQyxJQUFJLENBQUNELFNBQVNHLFlBQVk7WUFDeEIsT0FBTyxDQUFDO1FBQ1Y7UUFDQSxPQUFPUSxPQUFPQyxXQUFXLENBQUNaLFFBQVFHLFVBQVUsQ0FBQ1UsT0FBTztJQUN0RDtJQUVBLGtDQUFrQztJQUNsQyxnQ0FBZ0M7SUFDaEMsOEJBQThCO0lBQzlCLG9EQUFvRDtJQUNwRCxNQUFNO0lBQ04sOENBQThDO0lBQzlDLElBQUk7SUFFSixXQUFXO0lBQ1gsT0FBT0MsRUFBRUMsUUFBZ0IsRUFBRTtRQUN6QixrQkFBa0I7UUFDbEJDLFFBQVFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRUYsVUFBVTtJQUNuQztJQUNBLE9BQU9HLEVBQUVILFFBQWdCLEVBQUU7UUFDekIsa0JBQWtCO1FBQ2xCQyxRQUFRQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUVGLFVBQVU7SUFDbEM7SUFDQSxPQUFPSSxFQUFFSixRQUFnQixFQUFFO1FBQ3pCLGtCQUFrQjtRQUNsQkMsUUFBUUMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFRixVQUFVO0lBQ2xDO0lBQ0EsT0FBT0ssRUFBRUwsUUFBZ0IsRUFBRTtRQUN6QixrQkFBa0I7UUFDbEJDLFFBQVFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRUYsVUFBVTtJQUNuQztBQUNGIn0=
|
|
316
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/naite/naite.ts"],"sourcesContent":["/** biome-ignore-all lint/suspicious/noExplicitAny: Naite는 expect와 호응하도록 any를 허용함 */\n\nimport { get } from \"radashi\";\nimport { Sonamu } from \"../api/sonamu\";\nimport type { ComparisonOperator } from \"../database/puri.types\";\nimport { isSerializable } from \"../utils/object-utils\";\n\n// StackFrame 타입\ninterface StackFrame {\n  functionName: string | null;\n  filePath: string; // \"/Users/.../syncer.ts\" 또는 \"node:internal/...\"\n  lineNumber: number; // TS 파일 기준 라인 번호\n}\n\n// NaiteTrace 타입\ninterface NaiteTrace {\n  key: string;\n  data: any;\n  stack: StackFrame[]; // 콜스택 정보\n  at: Date;\n}\n\n// Naite.t가 저장되는 타입 (항상 배열로 통일)\nexport type NaiteStore = Map<string, NaiteTrace[]>;\n\n/**\n * 콜스택을 파싱하여 StackFrame 배열로 반환\n * - extractCallStack 자신과 Naite.t는 제외\n * - runWithContext/runWithMockContext 발견 시 거기서 종료\n * - node: 내부 경로는 포함하되, lineNumber는 path에 : 포함 시 붙이지 않음\n */\nfunction extractCallStack(): StackFrame[] {\n  const stack = new Error().stack;\n  if (!stack) return [];\n\n  const lines = stack.split(\"\\n\");\n\n  // 콜스택 구조:\n  // [0]: \"Error\"\n  // [1]: \"at extractCallStack\"\n  // [2]: \"at Naite.t\"\n  // [3]: 실제 호출 위치부터 시작\n  const frames = lines\n    .slice(3)\n    .map(parseStackFrame)\n    .filter((frame): frame is StackFrame => frame !== null);\n\n  // runWithContext 계열 함수 발견 시 거기서 자르기\n  const contextIndex = frames.findIndex(\n    (f) =>\n      f.functionName?.includes(\"runWithContext\") || f.functionName?.includes(\"runWithMockContext\"),\n  );\n\n  return contextIndex >= 0 ? frames.slice(0, contextIndex + 1) : frames;\n}\n\n/**\n * 콜스택 한 줄을 파싱\n * 형식1: \"at FunctionName (filePath:lineNumber:columnNumber)\"\n * 형식2: \"at filePath:lineNumber:columnNumber\" (익명 함수/모듈 레벨)\n */\nfunction parseStackFrame(line: string): StackFrame | null {\n  // 패턴1: \"at FunctionName (filePath:lineNumber:columnNumber)\"\n  const matchWithFunc = line.match(/at\\s+(.+?)\\s+\\((.+?):(\\d+):\\d+\\)/);\n  if (matchWithFunc) {\n    const functionName = matchWithFunc[1];\n    const filePath = matchWithFunc[2];\n    const lineNumberStr = matchWithFunc[3];\n\n    // filePath에 이미 :가 포함되어 있으면 (예: \"node:internal/...\")\n    if (filePath.includes(\":\")) {\n      return { functionName, filePath, lineNumber: 0 };\n    }\n\n    return {\n      functionName,\n      filePath,\n      lineNumber: Number.parseInt(lineNumberStr, 10),\n    };\n  }\n\n  // 패턴2: \"at filePath:lineNumber:columnNumber\" (함수명 없음)\n  const matchNoFunc = line.match(/at\\s+(.+?):(\\d+):\\d+$/);\n  if (matchNoFunc) {\n    const filePath = matchNoFunc[1];\n    const lineNumberStr = matchNoFunc[2];\n\n    return {\n      functionName: null,\n      filePath,\n      lineNumber: Number.parseInt(lineNumberStr, 10),\n    };\n  }\n\n  return null;\n}\n\n/**\n * wildcard 패턴 매칭\n * 예시:\n * - \"syncer:*\" → \"syncer:a\", \"syncer:a:b\" 모두 매칭\n * - \"syncer:*:user\" → \"syncer:renderTemplate:user\" 매칭\n * - \"syncer:renderTemplate:*\" → \"syncer:renderTemplate:service\" 매칭\n */\nfunction matchesPattern(key: string, pattern: string): boolean {\n  const keyParts = key.split(\":\");\n  const patternParts = pattern.split(\":\");\n\n  // 마지막이 * → prefix 매칭 (길이 무관)\n  // 예: \"syncer:*\"는 \"syncer:a\", \"syncer:a:b\" 모두 매칭\n  if (patternParts[patternParts.length - 1] === \"*\") {\n    const prefixParts = patternParts.slice(0, -1);\n    // prefix가 모두 일치하는지 확인\n    return prefixParts.every((part, i) => part === keyParts[i]);\n  }\n\n  // 길이가 같아야 함\n  if (patternParts.length !== keyParts.length) {\n    return false;\n  }\n\n  // 각 파트가 * 또는 정확히 일치\n  return patternParts.every((part, i) => part === \"*\" || part === keyParts[i]);\n}\n\n/**\n * NaiteQuery 클래스\n * 체이닝을 통한 trace 필터링 및 조회\n */\nexport class NaiteQuery {\n  constructor(private traces: NaiteTrace[]) {}\n\n  /**\n   * 파일명으로 필터링\n   * @param fileName 파일명 (예: \"syncer.test.ts\")\n   */\n  fromFile(fileName: string): NaiteQuery {\n    const filtered = this.traces.filter((t) =>\n      t.stack.some((frame) => frame.filePath.endsWith(`/${fileName}`)),\n    );\n    return new NaiteQuery(filtered);\n  }\n\n  /**\n   * 함수명으로 필터링\n   * @param funcName 함수명 (includes 체크)\n   * @param options.from 'direct' = 직접 호출만, 'indirect' = 간접 호출만, 'both' = 모두\n   */\n  fromFunction(\n    funcName: string,\n    options: { from: \"direct\" | \"indirect\" | \"both\" } = { from: \"both\" },\n  ): NaiteQuery {\n    const filtered = this.traces.filter((t) => {\n      if (options.from === \"direct\") {\n        // stack[0]만 확인 (직접 호출)\n        return t.stack[0]?.functionName?.includes(funcName);\n      }\n      if (options.from === \"indirect\") {\n        // stack[1+]에서 확인 (간접 호출)\n        return t.stack.slice(1).some((f) => f.functionName?.includes(funcName));\n      }\n      // 전체 스택에서 확인\n      return t.stack.some((f) => f.functionName?.includes(funcName));\n    });\n    return new NaiteQuery(filtered);\n  }\n\n  /**\n   * 데이터 경로 기반 필터링\n   * @param path radash get 경로 (예: \"data.userId\")\n   * @param operator 비교 연산자\n   * @param value 비교값\n   */\n  where(path: string, operator: ComparisonOperator | \"includes\", value: any): NaiteQuery {\n    const filtered = this.traces.filter((trace) => {\n      const actual = get(trace, path) as any;\n\n      switch (operator) {\n        case \">\":\n          return actual > value;\n        case \"<\":\n          return actual < value;\n        case \">=\":\n          return actual >= value;\n        case \"<=\":\n          return actual <= value;\n        case \"=\":\n          return actual === value;\n        case \"!=\":\n          return actual !== value;\n        case \"includes\":\n          return typeof actual === \"string\" && actual.includes(value);\n        default:\n          return false;\n      }\n    });\n    return new NaiteQuery(filtered);\n  }\n\n  /**\n   * 전체 데이터 배열 반환\n   */\n  result(): any[] {\n    return this.traces.map((t) => t.data);\n  }\n\n  /**\n   * 첫 번째 데이터 반환\n   */\n  first(): any | undefined {\n    return this.traces[0]?.data;\n  }\n\n  /**\n   * 마지막 데이터 반환\n   */\n  last(): any | undefined {\n    return this.traces[this.traces.length - 1]?.data;\n  }\n\n  /**\n   * n번째 데이터 반환\n   */\n  at(index: number): any | undefined {\n    return this.traces[index]?.data;\n  }\n\n  /**\n   * 원본 trace 배열 반환 (디버깅/NaiteViewer용)\n   */\n  getTraces(): NaiteTrace[] {\n    return this.traces;\n  }\n}\n\n// Naite 싱글턴 객체 (추후 logger 연결 등의 상태 관리 필요성 고려)\nexport class NaiteClass {\n  // 테스트 로그 기록\n  t(\n    name: string,\n    value: any /*이렇게 받은 값이 NaiteTrace로 저장되어 있다가 추후에 vitest에게 meta를 통해 넘겨져 프로세스간 통신을 통해 직렬화되어야 하는 점을 고려하였을 때 여기에 Serializable을 써서 제한을 둘 수도 있지만, 사용상의 편의를 생각하여 any로 받습니다.*/,\n  ) {\n    // 이 t 함수는 테스트 환경에서만 작동해야 합니다.\n    // 그리고 테스트 환경 판단에 왜 isTest() 함수를 사용하지 않았냐면요,,\n    // 이렇게 하는게 유틸 함수 불러와서 사용하는 것보다 조금이나마 빠를 것 같았기 때문입니다.\n    if (process.env.NODE_ENV !== \"test\") {\n      return;\n    }\n\n    try {\n      const context = Sonamu.getContext();\n      const store = context?.naiteStore;\n\n      if (!store) {\n        return;\n      }\n\n      // 콜스택 수집\n      const stack = extractCallStack();\n\n      const trace: NaiteTrace = {\n        key: name,\n        data: value,\n        stack,\n        at: new Date(),\n      };\n\n      // 항상 배열로 관리\n      const existing = store.get(name) ?? [];\n      store.set(name, [...existing, trace]);\n    } catch {\n      // Context 없는 상황에서 Naite.t 호출\n    }\n  }\n\n  /**\n   * key 또는 wildcard 패턴으로 trace 조회\n   * 항상 NaiteQuery 반환하여 체이닝 가능\n   */\n  get(keyPattern: string): NaiteQuery {\n    const context = Sonamu.getContext();\n    const store = context?.naiteStore;\n\n    if (!store) {\n      return new NaiteQuery([]);\n    }\n\n    // wildcard 없으면 exact match\n    if (!keyPattern.includes(\"*\")) {\n      const traces = store.get(keyPattern) ?? [];\n      return new NaiteQuery(traces);\n    }\n\n    // wildcard 패턴 매칭\n    const allTraces: NaiteTrace[] = [];\n    for (const [key, traces] of store.entries()) {\n      if (matchesPattern(key, keyPattern)) {\n        allTraces.push(...traces);\n      }\n    }\n\n    return new NaiteQuery(allTraces);\n  }\n\n  // 전체 리스트 가져오기\n  getAll(): { [key: string]: any } {\n    const context = Sonamu.getContext();\n    if (!context?.naiteStore) {\n      return {};\n    }\n    // NaiteTrace 배열을 data만 추출하여 반환\n    const result: { [key: string]: any } = {};\n    for (const [key, traces] of context.naiteStore.entries()) {\n      if (key.startsWith(\"mock:\")) {\n        // Mock 설정은 그대로 반환\n        result[key] = traces;\n      } else {\n        // NaiteTrace 배열은 data만 추출\n        result[key] = traces.map((t: NaiteTrace) => t.data);\n      }\n    }\n    return result;\n  }\n\n  /**\n   * 스토어에 들어있던 트레이스를 고대로 꺼내옵니다.\n   * 이때 값들은 모두 직렬화 가능한 상태로 나가게 됩니다.\n   * 테스트 정보와 함께 extensions에 보낼 용도로 만들었습니다.\n   * @returns\n   */\n  getAllTraces(): {\n    key: string;\n    value: any;\n    filePath: string;\n    lineNumber: number;\n    at: string;\n  }[] {\n    const context = Sonamu.getContext();\n    if (!context?.naiteStore) {\n      return [];\n    }\n\n    const traces = Array.from(context.naiteStore.values()).flat();\n\n    // 직렬화 불가능한 값이 존재한다면 이를 대문짝만하게 알려줍니다! 그치만 알리기만 하고 그냥 지나갑니다 ㅎㅎ\n    // 왜 직렬화가 중요한가? 이(getAllTraces) 호출의 결과는 외부로 나가게 되는데,\n    // 이때 주 용도가 vitest의 task.meta 필드를 통해 afterEach에서 Sonamu extension으로 전달하는 것입니다.\n    // 여기서 meta 필드에 담긴 내용은 프로세스간 통신(process.send) 또는 스레드간 통신(message port)을 통해 전달되어야 하는데,\n    // 이로 인해 \"직렬화 가능한 값들만 허용\"하는 제약이 생깁니다.\n    //\n    // 이 제약을 의식하여 Naite.t에 직렬화 가능한 값만 넘기게 할 수도 있었지만, 그렇게 하면 불편해질 것 같아서 하지 않았습니다.\n    // 따라서 현재 Naite.t는 모든 값을 받을 수 있게 되어 있습니다. \n    // 대신 이렇게(getAllTraces) 그 값들을 빼낼 때 JSON.stringify를 사용하여 강제로 직렬화 가능하게 만들었습니다,,\n    for (const trace of traces) {\n      const check = isSerializable(trace.data);\n      if (!check.valid) {\n        console.warn(\n          \"\\n\" +\n            \"╔════════════════════════════════════════════════════════════════╗\\n\" +\n            \"║  [Naite] Non-serializable value detected!                      ║\\n\" +\n            \"╠════════════════════════════════════════════════════════════════╣\\n\" +\n            `║  Key: ${trace.key.padEnd(57)}║\\n` +\n            `║  Reason: ${(check.reason ?? \"unknown\").slice(0, 54).padEnd(54)}║\\n` +\n            `║  Location: ${(trace.stack[0]?.filePath ?? \"unknown\").slice(-51).padEnd(52)}║\\n` +\n            `║  Line: ${String(trace.stack[0]?.lineNumber ?? 0).padEnd(56)}║\\n` +\n            \"╠════════════════════════════════════════════════════════════════╣\\n\" +\n            \"║  Naite.t() accepts any type of value. However, values will     ║\\n\" +\n            \"║  be serialized to JSON when exported via Naite.getAllTraces(). ║\\n\" +\n            \"╚════════════════════════════════════════════════════════════════╝\\n\",\n        );\n      }\n    }\n\n    return traces.map((trace) => ({\n      key: trace.key,\n      value: JSON.parse(JSON.stringify(trace.data ?? \"\")), // 직렬화 가능한 것만 남기려는 눈물겨운 노력,, 안그러면 task.meta에 들어가서 프로세스간 통신 할 때 문제 생기거든요,,\n      filePath: trace.stack[0]?.filePath ?? \"\",\n      lineNumber: trace.stack[0]?.lineNumber ?? 0,\n      at: trace.at.toISOString(),\n    }));\n  }\n\n  // 특정 키 삭제하기\n  del(key: string) {\n    const context = Sonamu.getContext();\n    if (!context?.naiteStore) {\n      return;\n    }\n    context.naiteStore.delete(key);\n  }\n\n  createStore(): NaiteStore {\n    return new Map<string, NaiteTrace[]>();\n  }\n\n  // 일반 로그 레벨\n  d(_message: string) {\n    // TODO: Logger 연결\n    console.log(`[DEBUG] ${_message}`);\n  }\n  i(_message: string) {\n    // TODO: Logger 연결\n    console.log(`[INFO] ${_message}`);\n  }\n  w(_message: string) {\n    // TODO: Logger 연결\n    console.log(`[WARN] ${_message}`);\n  }\n  e(_message: string) {\n    // TODO: Logger 연결\n    console.log(`[ERROR] ${_message}`);\n  }\n}\n\nexport const Naite = new NaiteClass();\n"],"names":["get","Sonamu","isSerializable","extractCallStack","stack","Error","lines","split","frames","slice","map","parseStackFrame","filter","frame","contextIndex","findIndex","f","functionName","includes","line","matchWithFunc","match","filePath","lineNumberStr","lineNumber","Number","parseInt","matchNoFunc","matchesPattern","key","pattern","keyParts","patternParts","length","prefixParts","every","part","i","NaiteQuery","traces","fromFile","fileName","filtered","t","some","endsWith","fromFunction","funcName","options","from","where","path","operator","value","trace","actual","result","data","first","last","at","index","getTraces","NaiteClass","name","process","env","NODE_ENV","context","getContext","store","naiteStore","Date","existing","set","keyPattern","allTraces","entries","push","getAll","startsWith","getAllTraces","Array","values","flat","check","valid","console","warn","padEnd","reason","String","JSON","parse","stringify","toISOString","del","delete","createStore","Map","d","_message","log","w","e","Naite"],"mappings":"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"}
|
package/dist/stream/sse.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import type {
|
|
1
|
+
import type { FastifyReply, FastifyRequest } from "fastify";
|
|
2
|
+
import type { z } from "zod";
|
|
3
3
|
export declare function createSSEFactory<T extends z.ZodObject>(socket: FastifyRequest["socket"], reply: FastifyReply, _events: T): SSEConnection<T>;
|
|
4
4
|
declare class SSEConnection<T extends z.ZodObject> {
|
|
5
5
|
private readonly socket;
|
package/dist/stream/sse.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse.d.ts","sourceRoot":"","sources":["../../src/stream/sse.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"sse.d.ts","sourceRoot":"","sources":["../../src/stream/sse.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC5D,OAAO,KAAK,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAG7B,wBAAgB,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS,EACpD,MAAM,EAAE,cAAc,CAAC,QAAQ,CAAC,EAChC,KAAK,EAAE,YAAY,EACnB,OAAO,EAAE,CAAC,oBAGX;AAED,cAAM,aAAa,CAAC,CAAC,SAAS,CAAC,CAAC,SAAS;IAIrC,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,KAAK;IAJxB,OAAO,CAAC,OAAO,CAAS;gBAGL,MAAM,EAAE,cAAc,CAAC,QAAQ,CAAC,EAChC,KAAK,EAAE,YAAY;IAOtC,OAAO,CAAC,CAAC,SAAS,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;IAWlE,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;CAa3B"}
|
package/dist/stream/sse.js
CHANGED
|
@@ -35,4 +35,4 @@ class SSEConnection {
|
|
|
35
35
|
}
|
|
36
36
|
}
|
|
37
37
|
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9zdHJlYW0vc3NlLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgRmFzdGlmeVJlcGx5LCBGYXN0aWZ5UmVxdWVzdCB9IGZyb20gXCJmYXN0aWZ5XCI7XG5pbXBvcnQgdHlwZSB7IHogfSBmcm9tIFwiem9kXCI7XG5cbi8vIE5PVEUoSGF6ZSwgMjUxMTA2KTogY29udGV4dCBwcm92aWRlcuyXkOyEnCDsnbjsnpDrpbwg7LGE7JuM7KO866m0IGNyZWF0ZVNTRShldmVudHMp66eM7Jy866GcIOyCrOyaqSDqsIDriqVcbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVTU0VGYWN0b3J5PFQgZXh0ZW5kcyB6LlpvZE9iamVjdD4oXG4gIHNvY2tldDogRmFzdGlmeVJlcXVlc3RbXCJzb2NrZXRcIl0sXG4gIHJlcGx5OiBGYXN0aWZ5UmVwbHksXG4gIF9ldmVudHM6IFQsXG4pIHtcbiAgcmV0dXJuIG5ldyBTU0VDb25uZWN0aW9uPFQ+KHNvY2tldCwgcmVwbHkpO1xufVxuXG5jbGFzcyBTU0VDb25uZWN0aW9uPFQgZXh0ZW5kcyB6LlpvZE9iamVjdD4ge1xuICBwcml2YXRlIF9jbG9zZWQgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwcml2YXRlIHJlYWRvbmx5IHNvY2tldDogRmFzdGlmeVJlcXVlc3RbXCJzb2NrZXRcIl0sXG4gICAgcHJpdmF0ZSByZWFkb25seSByZXBseTogRmFzdGlmeVJlcGx5LFxuICApIHtcbiAgICB0aGlzLnNvY2tldC5vbihcImNsb3NlXCIsICgpID0+IHtcbiAgICAgIHRoaXMuX2Nsb3NlZCA9IHRydWU7XG4gICAgfSk7XG4gIH1cblxuICBwdWJsaXNoPEsgZXh0ZW5kcyBrZXlvZiB6LmluZmVyPFQ+PihldmVudDogSywgZGF0YTogei5pbmZlcjxUPltLXSk6IHZvaWQge1xuICAgIGlmICh0aGlzLl9jbG9zZWQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICB0aGlzLnJlcGx5LnNzZSh7XG4gICAgICBldmVudDogZXZlbnQgYXMgc3RyaW5nLFxuICAgICAgZGF0YTogSlNPTi5zdHJpbmdpZnkoZGF0YSksXG4gICAgfSk7XG4gIH1cblxuICBhc3luYyBlbmQoKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgaWYgKHRoaXMuX2Nsb3NlZCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHRoaXMucmVwbHkuc3NlKHtcbiAgICAgIGV2ZW50OiBcImVuZFwiLFxuICAgICAgZGF0YTogXCJFTkRcIixcbiAgICB9KTtcblxuICAgIGF3YWl0IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiBzZXRUaW1lb3V0KHJlc29sdmUsIDIwMCkpO1xuICAgIHRoaXMucmVwbHkucmF3LmVuZCgpO1xuICB9XG59XG4iXSwibmFtZXMiOlsiY3JlYXRlU1NFRmFjdG9yeSIsInNvY2tldCIsInJlcGx5IiwiX2V2ZW50cyIsIlNTRUNvbm5lY3Rpb24iLCJfY2xvc2VkIiwib24iLCJwdWJsaXNoIiwiZXZlbnQiLCJkYXRhIiwic3NlIiwiSlNPTiIsInN0cmluZ2lmeSIsImVuZCIsIlByb21pc2UiLCJyZXNvbHZlIiwic2V0VGltZW91dCIsInJhdyJdLCJtYXBwaW5ncyI6IkFBR0EsNkVBQTZFO0FBQzdFLE9BQU8sU0FBU0EsaUJBQ2RDLE1BQWdDLEVBQ2hDQyxLQUFtQixFQUNuQkMsT0FBVTtJQUVWLE9BQU8sSUFBSUMsY0FBaUJILFFBQVFDO0FBQ3RDO0FBRUEsTUFBTUU7OztJQUNJQyxVQUFVLE1BQU07SUFFeEIsWUFDRSxBQUFpQkosTUFBZ0MsRUFDakQsQUFBaUJDLEtBQW1CLENBQ3BDO2FBRmlCRCxTQUFBQTthQUNBQyxRQUFBQTtRQUVqQixJQUFJLENBQUNELE1BQU0sQ0FBQ0ssRUFBRSxDQUFDLFNBQVM7WUFDdEIsSUFBSSxDQUFDRCxPQUFPLEdBQUc7UUFDakI7SUFDRjtJQUVBRSxRQUFvQ0MsS0FBUSxFQUFFQyxJQUFtQixFQUFRO1FBQ3ZFLElBQUksSUFBSSxDQUFDSixPQUFPLEVBQUU7WUFDaEI7UUFDRjtRQUVBLElBQUksQ0FBQ0gsS0FBSyxDQUFDUSxHQUFHLENBQUM7WUFDYkYsT0FBT0E7WUFDUEMsTUFBTUUsS0FBS0MsU0FBUyxDQUFDSDtRQUN2QjtJQUNGO0lBRUEsTUFBTUksTUFBcUI7UUFDekIsSUFBSSxJQUFJLENBQUNSLE9BQU8sRUFBRTtZQUNoQjtRQUNGO1FBRUEsSUFBSSxDQUFDSCxLQUFLLENBQUNRLEdBQUcsQ0FBQztZQUNiRixPQUFPO1lBQ1BDLE1BQU07UUFDUjtRQUVBLE1BQU0sSUFBSUssUUFBUSxDQUFDQyxVQUFZQyxXQUFXRCxTQUFTO1FBQ25ELElBQUksQ0FBQ2IsS0FBSyxDQUFDZSxHQUFHLENBQUNKLEdBQUc7SUFDcEI7QUFDRiJ9
|
|
@@ -1,20 +1,10 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { AbsolutePath } from "../utils/path-utils";
|
|
1
|
+
import { type ExtendedApi } from "../api/decorators";
|
|
2
|
+
import type { AbsolutePath } from "../utils/path-utils";
|
|
3
3
|
/**
|
|
4
4
|
* TypeScript 파일을 파싱하여 API 메소드 정보를 추출합니다.
|
|
5
5
|
* @api 데코레이터가 붙은 메소드들의 타입 정보를 분석합니다.
|
|
6
6
|
* @param filePath - 파싱할 TypeScript 파일의 절대 경로
|
|
7
7
|
* @returns API 메소드 정보 배열 (타입 파라미터, 파라미터, 리턴 타입 등)
|
|
8
8
|
*/
|
|
9
|
-
export declare function readApisFromFile(filePath: AbsolutePath): Promise<
|
|
10
|
-
typeParameters: ApiParamType.TypeParam[];
|
|
11
|
-
parameters: ApiParam[];
|
|
12
|
-
returnType: ApiParamType;
|
|
13
|
-
modelName: string;
|
|
14
|
-
methodName: string;
|
|
15
|
-
path: string;
|
|
16
|
-
options: import("..").ApiDecoratorOptions;
|
|
17
|
-
streamOptions?: import("..").StreamDecoratorOptions;
|
|
18
|
-
uploadOptions?: import("..").UploadDecoratorOptions;
|
|
19
|
-
}[]>;
|
|
9
|
+
export declare function readApisFromFile(filePath: AbsolutePath): Promise<ExtendedApi[]>;
|
|
20
10
|
//# sourceMappingURL=api-parser.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api-parser.d.ts","sourceRoot":"","sources":["../../src/syncer/api-parser.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"api-parser.d.ts","sourceRoot":"","sources":["../../src/syncer/api-parser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,WAAW,EAAkB,MAAM,mBAAmB,CAAC;AAGrE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAExD;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAAC,QAAQ,EAAE,YAAY,GAAG,OAAO,CAAC,WAAW,EAAE,CAAC,CAwGrF"}
|