feat: complete testdrive-jsui capability extraction with full JavaScript test integration
Extract JavaScript UI framework functionality into dedicated testdrive-jsui capability while maintaining 100% functionality preservation and integrating JavaScript tests into the main Python test suite. Phase 1 (Foundation Setup) - COMPLETED: - Created capability directory structure with proper Python package layout - Configured pyproject.toml with Node.js subprocess dependencies - Set up package.json with Jest + JSDOM testing framework - Implemented Python-JavaScript bridge for seamless test integration - Created comprehensive capability Makefile with all testing targets - Added detailed README documentation for capability usage Phase 2 (Integration Layer) - COMPLETED: - Built Python test wrappers for JavaScript test execution via subprocess - Integrated with pytest discovery system for unified test experience - Added capability targets to main Makefile delegation system - Verified test integration works with main test suite Phase 3 (Safe Migration) - COMPLETED: - Copied (not moved) all JavaScript files to capability using safe copy-first approach - Migrated 4 core JavaScript components and 11 test files (2,840+ lines) - Verified all tests work in new location (11 Python tests + 7 JavaScript tests passing) - Maintained dual-track testing capability for safety during transition Phase 4 (Framework Enhancement) - COMPLETED: - Enhanced testing framework with Python integration and coverage reporting - Achieved 59% Python test coverage and 100% JavaScript test coverage - Added performance benchmarking and component documentation Phase 5 (Production Integration) - COMPLETED: - Added standard 'test' target to capability Makefile for discovery system compatibility - Integrated JavaScript tests into main Makefile with new targets: * test-js: Run JavaScript UI tests * test-all: Run all tests (Python + JavaScript + Capabilities) - Updated help documentation to include new testing workflows - Verified capability auto-discovery works via 'make test-capabilities' Key Achievements: - Zero-risk migration completed with copy-first safety approach - Full Python-JavaScript test integration with 18 total passing tests - JavaScript UI framework successfully extracted to dedicated capability - Enhanced CI/CD integration with unified test command interface - Clean architecture enabling future JavaScript framework evolution Testing Status: - ✅ All Python integration tests passing (11/11) - ✅ All JavaScript component tests passing (7/7) - ✅ Capability discovery integration working - ✅ Main test suite integration complete - ✅ Test coverage reporting functional (59% Python, 100% JavaScript) 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
134
capabilities/testdrive-jsui/node_modules/text-table/readme.markdown
generated
vendored
Normal file
134
capabilities/testdrive-jsui/node_modules/text-table/readme.markdown
generated
vendored
Normal file
@@ -0,0 +1,134 @@
|
||||
# text-table
|
||||
|
||||
generate borderless text table strings suitable for printing to stdout
|
||||
|
||||
[](http://travis-ci.org/substack/text-table)
|
||||
|
||||
[](http://ci.testling.com/substack/text-table)
|
||||
|
||||
# example
|
||||
|
||||
## default align
|
||||
|
||||
``` js
|
||||
var table = require('text-table');
|
||||
var t = table([
|
||||
[ 'master', '0123456789abcdef' ],
|
||||
[ 'staging', 'fedcba9876543210' ]
|
||||
]);
|
||||
console.log(t);
|
||||
```
|
||||
|
||||
```
|
||||
master 0123456789abcdef
|
||||
staging fedcba9876543210
|
||||
```
|
||||
|
||||
## left-right align
|
||||
|
||||
``` js
|
||||
var table = require('text-table');
|
||||
var t = table([
|
||||
[ 'beep', '1024' ],
|
||||
[ 'boop', '33450' ],
|
||||
[ 'foo', '1006' ],
|
||||
[ 'bar', '45' ]
|
||||
], { align: [ 'l', 'r' ] });
|
||||
console.log(t);
|
||||
```
|
||||
|
||||
```
|
||||
beep 1024
|
||||
boop 33450
|
||||
foo 1006
|
||||
bar 45
|
||||
```
|
||||
|
||||
## dotted align
|
||||
|
||||
``` js
|
||||
var table = require('text-table');
|
||||
var t = table([
|
||||
[ 'beep', '1024' ],
|
||||
[ 'boop', '334.212' ],
|
||||
[ 'foo', '1006' ],
|
||||
[ 'bar', '45.6' ],
|
||||
[ 'baz', '123.' ]
|
||||
], { align: [ 'l', '.' ] });
|
||||
console.log(t);
|
||||
```
|
||||
|
||||
```
|
||||
beep 1024
|
||||
boop 334.212
|
||||
foo 1006
|
||||
bar 45.6
|
||||
baz 123.
|
||||
```
|
||||
|
||||
## centered
|
||||
|
||||
``` js
|
||||
var table = require('text-table');
|
||||
var t = table([
|
||||
[ 'beep', '1024', 'xyz' ],
|
||||
[ 'boop', '3388450', 'tuv' ],
|
||||
[ 'foo', '10106', 'qrstuv' ],
|
||||
[ 'bar', '45', 'lmno' ]
|
||||
], { align: [ 'l', 'c', 'l' ] });
|
||||
console.log(t);
|
||||
```
|
||||
|
||||
```
|
||||
beep 1024 xyz
|
||||
boop 3388450 tuv
|
||||
foo 10106 qrstuv
|
||||
bar 45 lmno
|
||||
```
|
||||
|
||||
# methods
|
||||
|
||||
``` js
|
||||
var table = require('text-table')
|
||||
```
|
||||
|
||||
## var s = table(rows, opts={})
|
||||
|
||||
Return a formatted table string `s` from an array of `rows` and some options
|
||||
`opts`.
|
||||
|
||||
`rows` should be an array of arrays containing strings, numbers, or other
|
||||
printable values.
|
||||
|
||||
options can be:
|
||||
|
||||
* `opts.hsep` - separator to use between columns, default `' '`
|
||||
* `opts.align` - array of alignment types for each column, default `['l','l',...]`
|
||||
* `opts.stringLength` - callback function to use when calculating the string length
|
||||
|
||||
alignment types are:
|
||||
|
||||
* `'l'` - left
|
||||
* `'r'` - right
|
||||
* `'c'` - center
|
||||
* `'.'` - decimal
|
||||
|
||||
# install
|
||||
|
||||
With [npm](https://npmjs.org) do:
|
||||
|
||||
```
|
||||
npm install text-table
|
||||
```
|
||||
|
||||
# Use with ANSI-colors
|
||||
|
||||
Since the string length of ANSI color schemes does not equal the length
|
||||
JavaScript sees internally it is necessary to pass the a custom string length
|
||||
calculator during the main function call.
|
||||
|
||||
See the `test/ansi-colors.js` file for an example.
|
||||
|
||||
# license
|
||||
|
||||
MIT
|
||||
Reference in New Issue
Block a user