 aacb45156b
			
		
	
	aacb45156b
	
	
	
		
			
			- Install Jest for unit testing with React Testing Library - Install Playwright for end-to-end testing - Configure Jest with proper TypeScript support and module mapping - Create test setup files and utilities for both unit and e2e tests Components: * Jest configuration with coverage thresholds * Playwright configuration with browser automation * Unit tests for LoginForm, AuthContext, and useSocketIO hook * E2E tests for authentication, dashboard, and agents workflows * GitHub Actions workflow for automated testing * Mock data and API utilities for consistent testing * Test documentation with best practices Testing features: - Unit tests with 70% coverage threshold - E2E tests with API mocking and user journey testing - CI/CD integration for automated test runs - Cross-browser testing support with Playwright - Authentication system testing end-to-end 🚀 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
		
			
				
	
	
		
			149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| //.CommonJS
 | |
| var CSSOM = {};
 | |
| ///CommonJS
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * @constructor
 | |
|  * @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration
 | |
|  */
 | |
| CSSOM.CSSStyleDeclaration = function CSSStyleDeclaration(){
 | |
| 	this.length = 0;
 | |
| 	this.parentRule = null;
 | |
| 
 | |
| 	// NON-STANDARD
 | |
| 	this._importants = {};
 | |
| };
 | |
| 
 | |
| 
 | |
| CSSOM.CSSStyleDeclaration.prototype = {
 | |
| 
 | |
| 	constructor: CSSOM.CSSStyleDeclaration,
 | |
| 
 | |
| 	/**
 | |
| 	 *
 | |
| 	 * @param {string} name
 | |
| 	 * @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-getPropertyValue
 | |
| 	 * @return {string} the value of the property if it has been explicitly set for this declaration block.
 | |
| 	 * Returns the empty string if the property has not been set.
 | |
| 	 */
 | |
| 	getPropertyValue: function(name) {
 | |
| 		return this[name] || "";
 | |
| 	},
 | |
| 
 | |
| 	/**
 | |
| 	 *
 | |
| 	 * @param {string} name
 | |
| 	 * @param {string} value
 | |
| 	 * @param {string} [priority=null] "important" or null
 | |
| 	 * @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-setProperty
 | |
| 	 */
 | |
| 	setProperty: function(name, value, priority) {
 | |
| 		if (this[name]) {
 | |
| 			// Property already exist. Overwrite it.
 | |
| 			var index = Array.prototype.indexOf.call(this, name);
 | |
| 			if (index < 0) {
 | |
| 				this[this.length] = name;
 | |
| 				this.length++;
 | |
| 			}
 | |
| 		} else {
 | |
| 			// New property.
 | |
| 			this[this.length] = name;
 | |
| 			this.length++;
 | |
| 		}
 | |
| 		this[name] = value + "";
 | |
| 		this._importants[name] = priority;
 | |
| 	},
 | |
| 
 | |
| 	/**
 | |
| 	 *
 | |
| 	 * @param {string} name
 | |
| 	 * @see http://www.w3.org/TR/DOM-Level-2-Style/css.html#CSS-CSSStyleDeclaration-removeProperty
 | |
| 	 * @return {string} the value of the property if it has been explicitly set for this declaration block.
 | |
| 	 * Returns the empty string if the property has not been set or the property name does not correspond to a known CSS property.
 | |
| 	 */
 | |
| 	removeProperty: function(name) {
 | |
| 		if (!(name in this)) {
 | |
| 			return "";
 | |
| 		}
 | |
| 		var index = Array.prototype.indexOf.call(this, name);
 | |
| 		if (index < 0) {
 | |
| 			return "";
 | |
| 		}
 | |
| 		var prevValue = this[name];
 | |
| 		this[name] = "";
 | |
| 
 | |
| 		// That's what WebKit and Opera do
 | |
| 		Array.prototype.splice.call(this, index, 1);
 | |
| 
 | |
| 		// That's what Firefox does
 | |
| 		//this[index] = ""
 | |
| 
 | |
| 		return prevValue;
 | |
| 	},
 | |
| 
 | |
| 	getPropertyCSSValue: function() {
 | |
| 		//FIXME
 | |
| 	},
 | |
| 
 | |
| 	/**
 | |
| 	 *
 | |
| 	 * @param {String} name
 | |
| 	 */
 | |
| 	getPropertyPriority: function(name) {
 | |
| 		return this._importants[name] || "";
 | |
| 	},
 | |
| 
 | |
| 
 | |
| 	/**
 | |
| 	 *   element.style.overflow = "auto"
 | |
| 	 *   element.style.getPropertyShorthand("overflow-x")
 | |
| 	 *   -> "overflow"
 | |
| 	 */
 | |
| 	getPropertyShorthand: function() {
 | |
| 		//FIXME
 | |
| 	},
 | |
| 
 | |
| 	isPropertyImplicit: function() {
 | |
| 		//FIXME
 | |
| 	},
 | |
| 
 | |
| 	// Doesn't work in IE < 9
 | |
| 	get cssText(){
 | |
| 		var properties = [];
 | |
| 		for (var i=0, length=this.length; i < length; ++i) {
 | |
| 			var name = this[i];
 | |
| 			var value = this.getPropertyValue(name);
 | |
| 			var priority = this.getPropertyPriority(name);
 | |
| 			if (priority) {
 | |
| 				priority = " !" + priority;
 | |
| 			}
 | |
| 			properties[i] = name + ": " + value + priority + ";";
 | |
| 		}
 | |
| 		return properties.join(" ");
 | |
| 	},
 | |
| 
 | |
| 	set cssText(text){
 | |
| 		var i, name;
 | |
| 		for (i = this.length; i--;) {
 | |
| 			name = this[i];
 | |
| 			this[name] = "";
 | |
| 		}
 | |
| 		Array.prototype.splice.call(this, 0, this.length);
 | |
| 		this._importants = {};
 | |
| 
 | |
| 		var dummyRule = CSSOM.parse('#bogus{' + text + '}').cssRules[0].style;
 | |
| 		var length = dummyRule.length;
 | |
| 		for (i = 0; i < length; ++i) {
 | |
| 			name = dummyRule[i];
 | |
| 			this.setProperty(dummyRule[i], dummyRule.getPropertyValue(name), dummyRule.getPropertyPriority(name));
 | |
| 		}
 | |
| 	}
 | |
| };
 | |
| 
 | |
| 
 | |
| //.CommonJS
 | |
| exports.CSSStyleDeclaration = CSSOM.CSSStyleDeclaration;
 | |
| CSSOM.parse = require('./parse').parse; // Cannot be included sooner due to the mutual dependency between parse.js and CSSStyleDeclaration.js
 | |
| ///CommonJS
 |