feat: Add configurable sensitive data masking with custom patterns #5109
+449
−35
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR adds comprehensive sensitive data masking capabilities to CodeceptJS, allowing users to define custom patterns to obfuscate sensitive information like emails, credit cards, phone numbers, and other data in all output including logs, steps, debug messages, and error messages.
Overview
CodeceptJS can now automatically mask sensitive data in all output using the enhanced
maskSensitiveData
configuration option. This builds upon the existing boolean configuration to support custom regex patterns with user-defined mask strings.Configuration
Backward Compatible Boolean Configuration
Advanced Custom Patterns Configuration
Example Output
With the above configuration, sensitive data is automatically masked:
Before:
After:
Where Masking Applies
--debug
mode)--verbose
mode)secret()
function)Implementation Details
lib/utils/mask_data.js
) handles both boolean and object configurationslib/output.js
) applies masking consistently across all output methodsinvisi-data
package which already supports custom patternssecret()
functionTesting
All existing functionality continues to work unchanged:
secret()
function still masks individual valuesmaskSensitiveData: true
configuration works as beforeFixes #5108.
Warning
Firewall rules blocked me from connecting to one or more addresses (expand for details)
I tried to connect to the following addresses, but was blocked by firewall rules:
googlechromelabs.github.io
https://storage.googleapis.com/chrome-for-testing-public/138.0.7204.168/linux64/chrome-headless-shell-linux64.zip
node install.mjs
(http block)If you need me to access, download, or install something from one of these locations, you can either:
💡 You can make Copilot smarter by setting up custom instructions, customizing its development environment and configuring Model Context Protocol (MCP) servers. Learn more Copilot coding agent tips in the docs.