{"id":16017179,"url":"https://github.com/dexit-framework/dexit","last_synced_at":"2026-02-12T06:12:46.197Z","repository":{"id":57115009,"uuid":"154417829","full_name":"dexit-framework/dexit","owner":"dexit-framework","description":"Declarative Extensible Integration Testing Framework","archived":false,"fork":false,"pushed_at":"2018-10-24T01:08:20.000Z","size":81,"stargazers_count":2,"open_issues_count":0,"forks_count":1,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-10-10T09:29:09.121Z","etag":null,"topics":["api-testing","declarative","integration-testing","rest-api","test","testing","testing-framework","yaml"],"latest_commit_sha":null,"homepage":null,"language":"TypeScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"other","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dexit-framework.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2018-10-24T01:07:42.000Z","updated_at":"2024-08-30T15:15:00.000Z","dependencies_parsed_at":"2022-08-22T06:31:36.452Z","dependency_job_id":null,"html_url":"https://github.com/dexit-framework/dexit","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/dexit-framework/dexit","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dexit-framework%2Fdexit","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dexit-framework%2Fdexit/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dexit-framework%2Fdexit/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dexit-framework%2Fdexit/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dexit-framework","download_url":"https://codeload.github.com/dexit-framework/dexit/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dexit-framework%2Fdexit/sbom","scorecard":{"id":338740,"data":{"date":"2025-08-11","repo":{"name":"github.com/dexit-framework/dexit","commit":"9d9fc46238d92bf8732a4fa5b360f32058ccaa0e"},"scorecard":{"version":"v5.2.1-40-gf6ed084d","commit":"f6ed084d17c9236477efd66e5b258b9d4cc7b389"},"score":1.7,"checks":[{"name":"SAST","score":0,"reason":"no SAST tool detected","details":["Warn: no pull requests merged into dev branch"],"documentation":{"short":"Determines if the project uses static code analysis.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#sast"}},{"name":"Code-Review","score":0,"reason":"Found 0/5 approved changesets -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project requires human code review before pull requests (aka merge requests) are merged.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#code-review"}},{"name":"Packaging","score":-1,"reason":"packaging workflow not detected","details":["Warn: no GitHub/GitLab publishing workflow detected."],"documentation":{"short":"Determines if the project is published as a package that others can easily download, install, easily update, and uninstall.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#packaging"}},{"name":"Dangerous-Workflow","score":-1,"reason":"no workflows found","details":null,"documentation":{"short":"Determines if the project's GitHub Action workflows avoid dangerous patterns.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#dangerous-workflow"}},{"name":"Binary-Artifacts","score":10,"reason":"no binaries found in the repo","details":null,"documentation":{"short":"Determines if the project has generated executable (binary) artifacts in the source repository.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#binary-artifacts"}},{"name":"Maintained","score":0,"reason":"0 commit(s) and 0 issue activity found in the last 90 days -- score normalized to 0","details":null,"documentation":{"short":"Determines if the project is \"actively maintained\".","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#maintained"}},{"name":"Pinned-Dependencies","score":-1,"reason":"no dependencies found","details":null,"documentation":{"short":"Determines if the project has declared and pinned the dependencies of its build process.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#pinned-dependencies"}},{"name":"Token-Permissions","score":-1,"reason":"No tokens found","details":null,"documentation":{"short":"Determines if the project's workflows follow the principle of least privilege.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#token-permissions"}},{"name":"CII-Best-Practices","score":0,"reason":"no effort to earn an OpenSSF best practices badge detected","details":null,"documentation":{"short":"Determines if the project has an OpenSSF (formerly CII) Best Practices Badge.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#cii-best-practices"}},{"name":"Security-Policy","score":0,"reason":"security policy file not detected","details":["Warn: no security policy file detected","Warn: no security file to analyze","Warn: no security file to analyze","Warn: no security file to analyze"],"documentation":{"short":"Determines if the project has published a security policy.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#security-policy"}},{"name":"Fuzzing","score":0,"reason":"project is not fuzzed","details":["Warn: no fuzzer integrations found"],"documentation":{"short":"Determines if the project uses fuzzing.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#fuzzing"}},{"name":"License","score":9,"reason":"license file detected","details":["Info: project has a license file: LICENSE:0","Warn: project license file does not contain an FSF or OSI license."],"documentation":{"short":"Determines if the project has defined a license.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#license"}},{"name":"Signed-Releases","score":-1,"reason":"no releases found","details":null,"documentation":{"short":"Determines if the project cryptographically signs release artifacts.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#signed-releases"}},{"name":"Branch-Protection","score":0,"reason":"branch protection not enabled on development/release branches","details":["Warn: branch protection not enabled for branch 'master'"],"documentation":{"short":"Determines if the default and release branches are protected with GitHub's branch protection settings.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#branch-protection"}},{"name":"Vulnerabilities","score":0,"reason":"67 existing vulnerabilities detected","details":["Warn: Project is vulnerable to: GHSA-6chw-6frg-f759","Warn: Project is vulnerable to: GHSA-v88g-cgmw-v5xw","Warn: Project is vulnerable to: GHSA-93q8-gq69-wqmw","Warn: Project is vulnerable to: GHSA-fwr7-v2mv-hh25","Warn: Project is vulnerable to: GHSA-67hx-6x53-jw92","Warn: Project is vulnerable to: GHSA-v6h2-p8h4-qcjw","Warn: Project is vulnerable to: GHSA-cwfw-4gq5-mrqx","Warn: Project is vulnerable to: GHSA-g95f-p29q-9xw4","Warn: Project is vulnerable to: GHSA-grv7-fg5c-xmjg","Warn: Project is vulnerable to: GHSA-c6rq-rjc2-86v2","Warn: Project is vulnerable to: GHSA-3xgq-45jj-v275","Warn: Project is vulnerable to: GHSA-gxpj-cx7g-858c","Warn: Project is vulnerable to: GHSA-w573-4hg7-7wgq","Warn: Project is vulnerable to: GHSA-fjxv-7rqg-78g4","Warn: Project is vulnerable to: GHSA-8r6j-v8pm-fqw3","Warn: Project is vulnerable to: MAL-2023-462","Warn: Project is vulnerable to: GHSA-q42p-pg8m-cqh6","Warn: Project is vulnerable to: GHSA-w457-6q6x-cgp9","Warn: Project is vulnerable to: GHSA-62gr-4qp9-h98f","Warn: Project is vulnerable to: GHSA-f52g-6jhx-586p","Warn: Project is vulnerable to: GHSA-2cf5-4w76-r9qv","Warn: Project is vulnerable to: GHSA-3cqr-58rm-57f8","Warn: Project is vulnerable to: GHSA-g9r4-xpmj-mj65","Warn: Project is vulnerable to: GHSA-q2c6-c6pm-g3gh","Warn: Project is vulnerable to: GHSA-765h-qjxv-5f44","Warn: Project is vulnerable to: GHSA-f2jv-r9rf-7988","Warn: Project is vulnerable to: GHSA-43f8-2h32-f4cj","Warn: Project is vulnerable to: GHSA-qqgx-2p2h-9c37","Warn: Project is vulnerable to: GHSA-2pr6-76vf-7546","Warn: Project is vulnerable to: GHSA-8j8c-7jfh-h6hx","Warn: Project is vulnerable to: GHSA-896r-f27r-55mw","Warn: Project is vulnerable to: GHSA-9c47-m6qq-7p4h","Warn: Project is vulnerable to: GHSA-6c8f-qphg-qjgp","Warn: Project is vulnerable to: GHSA-jf85-cpcp-j695","Warn: Project is vulnerable to: GHSA-p6mc-m468-83gw","Warn: Project is vulnerable to: GHSA-29mw-wpgm-hmr9","Warn: Project is vulnerable to: GHSA-35jh-r3h4-6jhm","Warn: Project is vulnerable to: GHSA-4xcv-9jjx-gfj3","Warn: Project is vulnerable to: GHSA-f9cm-qmx5-m98h","Warn: Project is vulnerable to: GHSA-7wpw-2hjm-89gp","Warn: Project is vulnerable to: GHSA-952p-6rrq-rcjv","Warn: Project is vulnerable to: GHSA-f8q6-p94x-37v3","Warn: Project is vulnerable to: GHSA-vh95-rmgr-6w4m","Warn: Project is vulnerable to: GHSA-xvch-5gv4-984h","Warn: Project is vulnerable to: GHSA-fhjf-83wg-r2j9","Warn: Project is vulnerable to: GHSA-5fw9-fq32-wv5p","Warn: Project is vulnerable to: GHSA-hj48-42vr-x3v9","Warn: Project is vulnerable to: GHSA-hrpp-h998-j3pp","Warn: Project is vulnerable to: GHSA-p8p7-x288-28g6","Warn: Project is vulnerable to: GHSA-c2qf-rxjj-qqgw","Warn: Project is vulnerable to: GHSA-4g88-fppr-53pp","Warn: Project is vulnerable to: GHSA-4jqc-8m5r-9rpr","Warn: Project is vulnerable to: GHSA-x9hc-rw35-f44h","Warn: Project is vulnerable to: GHSA-j44m-qm6p-hp7m","Warn: Project is vulnerable to: GHSA-3jfq-g458-7qm9","Warn: Project is vulnerable to: GHSA-r628-mhmh-qjhw","Warn: Project is vulnerable to: GHSA-9r2w-394v-53qc","Warn: Project is vulnerable to: GHSA-5955-9wpr-37jh","Warn: Project is vulnerable to: GHSA-qq89-hq3f-393p","Warn: Project is vulnerable to: GHSA-f5x3-32g6-xq36","Warn: Project is vulnerable to: GHSA-jgrx-mgxx-jf9v","Warn: Project is vulnerable to: GHSA-72xf-g2v4-qvf3","Warn: Project is vulnerable to: GHSA-cf4h-3jhx-xvhq","Warn: Project is vulnerable to: GHSA-6fc8-4gx4-v693","Warn: Project is vulnerable to: GHSA-3h5v-q93c-6h6q","Warn: Project is vulnerable to: GHSA-c4w7-xm78-47vh","Warn: Project is vulnerable to: GHSA-p9pc-299p-vxgp"],"documentation":{"short":"Determines if the project has open, known unfixed vulnerabilities.","url":"https://github.com/ossf/scorecard/blob/f6ed084d17c9236477efd66e5b258b9d4cc7b389/docs/checks.md#vulnerabilities"}}]},"last_synced_at":"2025-08-18T05:18:02.914Z","repository_id":57115009,"created_at":"2025-08-18T05:18:02.914Z","updated_at":"2025-08-18T05:18:02.914Z"},"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":29360491,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-02-12T01:03:07.613Z","status":"online","status_checked_at":"2026-02-12T02:00:06.911Z","response_time":55,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["api-testing","declarative","integration-testing","rest-api","test","testing","testing-framework","yaml"],"created_at":"2024-10-08T16:04:22.663Z","updated_at":"2026-02-12T06:12:46.171Z","avatar_url":"https://github.com/dexit-framework.png","language":"TypeScript","readme":"# dexit\n\nDeclarative Extensible Integration Testing framework.\n\nThe Dexit aims to create a framework for integration testing of complex applications which consist of various services such as API servers, databases, pub/sub systems and so on. The Dexit allows you to easily test these services altogether.\n\n**Why declarative approach instead of programming?**\n\n- Because most of the integrations tests are about requesting or querying some service and then checking its response.\n- A declarative approach using YAML files is more understandable even for non-programmers.\n- For some people seems to be more readable.\n- Easy inheritance of configuration and parameters.\n\n## Usage\n\n### Stand-alone Project\n\n```bash\ncd your_project_dir\n\n# Create folder for tests\nmkdir -p ./tests\n\n# Create a new Node.JS module\nnpm init\n\n# Install Dexit\nnpm install --save @dexit/dexit\n\n# Install additional modules (currently not working)\n# npm install --save @dexit/module-http\n# npm install --save @dexit/module-mqtt\n# npm install --save @dexit/reporter-junit\n\n# Customize Dexit configuration using package.json\nnano package.json\n\n# Run tests\n./node_modules/.bin/dexit\n\n# Or if you install dexit globally\ndexit\n\n# Or if you add npm script as shown below...\nnpm run test\n```\n\n### As a Part of an Existing Node.JS Project\n\n```bash\ncd your_project_dir\n\n# Create folder for tests\nmkdir -p ./tests\n\n# Install Dexit\nnpm install --save @dexit/dexit\n\n# Install additional modules (currently not working)\n# npm install --save @dexit/module-http\n# npm install --save @dexit/module-mqtt\n# npm install --save @dexit/reporter-junit\n\n# Customize Dexit configuration using package.json\nnano package.json\n\n# Run tests\n./node_modules/.bin/dexit\n\n# Or if you install dexit globally\ndexit\n\n# Or if you add npm script as shown below...\nnpm run test\n```\n\n### Configuration\n\nConfiguration can be done via `package.json` file or using command line arguments.\n\nFor command line arguments run `dexit -h` or `./node_modules/.bin/dexit -h`.\n\n**Example configuration with default values using package.json file:**\n\n```json\n{\n  \"name\": \"demo\",\n  \"version\": \"1.0.0\",\n  \"scripts\": {\n    \"test\": \"./node_modules/.bin/dexit -h\"\n  },\n  \"dependencies\": {\n    \"@dexit/dexit\": \"*\"\n  },\n  \"dexit\": {\n    \"reporters\": {\n      \"console\": {\n        \"detailed\": false,\n        \"reportValidTasks\": false,\n        \"reportArgs\": false\n      }\n    },\n    \"ignoreInvalidTests\": true,\n    \"loadBuiltInModules\": true,\n    \"autoloadModules\": true,\n    \"testsPath\": \"./tests\",\n    \"modulesPath\": \"./node_modules\"\n  }\n}\n```\n\n**Example of CLI Help:**\n\n```\nusage: dexit [-h] [-v] [--base-path BASEPATH] [--modules-path MODULESPATH]\n              [--no-autoload] [--no-builtin] [--ignore-invalid]\n              [--reporter [module_name [module_name ...]]] [--debug]\n              [--generate-schema schema_filename]\n              [testsPath [testsPath ...]]\n\nDEXIT v0.1.0 (Declarative Extensible Integration Testing)\n\nPositional arguments:\n  testsPath             Tests directory path\n\nOptional arguments:\n  -h, --help            Show this help message and exit.\n  -v, --version         Show program's version number and exit.\n  --base-path BASEPATH  Base project path\n  --modules-path MODULESPATH\n                        Node modules path\n  --no-autoload         Disable autoloading of modules\n  --no-builtin          Disable autoloading of built-in modules\n  --ignore-invalid      Ignore invalid test files\n  --reporter [module_name [module_name ...]]\n                        Use reporter (default: console)\n  --debug               Print bootstrap debug messages\n  --generate-schema schema_filename\n                        Generate JSON schema for test files including all\n                        loaded modules definitions. Can be used for linters\n                        or language servers to enable intellisense. No tests\n                        will be run when this option is set.\n```\n\n## Built-in Testing Modules\n\n- JavaScript code execution\n\n## Built-in Reporters\n\n- Console\n\n## Planned Official Modules\n\n- REST API (as HTTP)\n- Shell commands execution\n- MySQL\n- PostgreSQL\n- InfluxDB\n- MQTT\n- RabbitMQ\n- Redis\n\n## Planned Official Reporters\n\n- JUnit\n- JSON\n- HTML\n\n## Documentation\n\nWill be published soon.\n\n## IntelliSense for VS Code\n\nIn Visual Studio Code, you can enable IntelliSense features for your test files as follows.\n\n1. Install [YAML Support by Red Hat](https://marketplace.visualstudio.com/items?itemName=redhat.vscode-yaml) extension\n2. Generate JSON schema file for your project using `./node_modules/.bin/dexit --generate-schema ./schema.json`\n3. Create a new workspace for your project (or use absolute path starting with `file://` in step 4)\n4. Add following properties to your workspace configuration:\n```json\n\"settings\": {\n  \"yaml.schemas\": {\n    \"./schema.json\": \"tests/***.yaml\"\n  }\n}\n```\n5. Enjoy\n\n## License Apache 2.0\n\nCopyright 2018 Jiri Hybek \u003cjiri@hybek.cz\u003e\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n    http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdexit-framework%2Fdexit","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdexit-framework%2Fdexit","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdexit-framework%2Fdexit/lists"}