Files
markitect-main/capabilities/testdrive-jsui/node_modules/es-abstract/helpers/CharSet.js
tegwick 17c62aadaa 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>
2025-11-09 22:29:30 +01:00

131 lines
3.3 KiB
JavaScript

'use strict';
var $TypeError = require('es-errors/type');
var GetIntrinsic = require('get-intrinsic');
var callBound = require('call-bound');
var hasOwn = require('hasown');
var caseFolding = require('./caseFolding.json');
var IsArray = require('./IsArray');
var isLeadingSurrogate = require('./isLeadingSurrogate');
var isTrailingSurrogate = require('./isTrailingSurrogate');
var $charCodeAt = callBound('%String.prototype.charCodeAt%');
var $fromCharCode = GetIntrinsic('%String.fromCharCode%');
/* eslint func-style: 0 */
function CharSet(test, yieldCh) {
if (typeof test !== 'function') {
throw new $TypeError('Assertion failed: `test` must be a function');
}
if (typeof yieldCh !== 'function') {
throw new $TypeError('Assertion failed: `yield` must be a function');
}
this.test = test;
this.yield = yieldCh;
}
CharSet.prototype.count = function () {
var count = 0;
this.yield(function () { count += 1; });
return count;
};
function testCodeUnits(CharSetElement) {
if (typeof CharSetElement !== 'string') {
throw new $TypeError('Assertion failed: `CharSetElement` must be a string');
}
return CharSetElement.length !== 1;
}
function yieldCodeUnits(emit) {
for (var i = 0; i <= 0xDFFF; i += 1) {
emit($fromCharCode(i));
}
}
function testCodePoints(CharSetElement) {
if (typeof CharSetElement !== 'string') {
throw new $TypeError('Assertion failed: `CharSetElement` must be a string');
}
if (CharSetElement.length === 1) {
return true;
}
if (CharSetElement.length === 2) {
var hi = $charCodeAt(CharSetElement, 0);
var lo = $charCodeAt(CharSetElement, 1);
return isLeadingSurrogate(hi) && isTrailingSurrogate(lo);
}
return false;
}
function yieldCodePoints(emit) {
for (var i = 0; i <= 0xDFFF; i += 1) {
emit($fromCharCode(i));
}
for (var u = 0x10000; u <= 0x10FFFF; u += 1) {
var cp = u - 0x10000;
var high = (cp >> 10) + 0xD800;
var low = (cp & 0x3FF) + 0xDC00;
emit($fromCharCode(high, low));
}
}
function charsToMap(chars) {
if (!IsArray(chars)) {
throw new $TypeError('Assertion failed: `chars` must be an array');
}
var map = { __proto__: null };
for (var i = 0; i < chars.length; i += 1) {
var char = chars[i];
if (typeof char !== 'string' || (char.length !== 1 && char.length !== 2)) {
throw new $TypeError('Assertion failed: `chars` must be an array of strings of length 1');
}
map[char] = true;
}
return map;
}
module.exports = {
CharSet: CharSet,
from: function from(chars) {
var map = charsToMap(chars);
return new CharSet(
function test(CharSetElement) {
return hasOwn(map, CharSetElement);
},
function yieldChar(emit) {
// eslint-disable-next-line no-restricted-syntax
for (var k in map) {
if (hasOwn(map, k)) {
emit(k);
}
}
}
);
},
getCodeUnits: function () {
return new CharSet(testCodeUnits, yieldCodeUnits);
},
getCodePoints: function () {
return new CharSet(testCodePoints, yieldCodePoints);
},
getNonSimpleCaseFoldingCodePoints: function () {
return new CharSet(
function test(CharSetElement) {
return testCodePoints(CharSetElement) && !hasOwn(caseFolding.S, CharSetElement);
},
function yieldChar(emit) {
yieldCodePoints(function (CharSetElement) {
if (!hasOwn(caseFolding.S, CharSetElement)) {
emit(CharSetElement);
}
});
}
);
}
};