diff --git a/.wp-env.json b/.wp-env.json index 4b8b9bcb5..d3be216b9 100644 --- a/.wp-env.json +++ b/.wp-env.json @@ -1,5 +1,4 @@ { - "core": "WordPress/WordPress#6.1", "plugins": [".", "./tests/test-plugin", "https://downloads.wordpress.org/plugin/classic-editor.zip"], "env": { "tests": { diff --git a/includes/Classifai/Features/Feature.php b/includes/Classifai/Features/Feature.php index b969ac2c6..6678adc6a 100644 --- a/includes/Classifai/Features/Feature.php +++ b/includes/Classifai/Features/Feature.php @@ -852,7 +852,8 @@ public function render_auto_caption_fields( array $args ) { * @param array $args The args passed to add_settings_field */ public function render_radio_group( array $args = array() ) { - $setting_index = $this->get_settings(); + $option_index = isset( $args['option_index'] ) ? $args['option_index'] : false; + $setting_index = $this->get_settings( $option_index ); $value = $setting_index[ $args['label_for'] ] ?? ''; $options = $args['options'] ?? []; @@ -865,12 +866,13 @@ public function render_radio_group( array $args = array() ) { // Render radio button. printf( '

-

', esc_attr( $this->get_option_name() ), + $option_index ? '[' . esc_attr( $option_index ) . ']' : '', esc_attr( $args['label_for'] ), esc_attr( $option_value ), checked( $value, $option_value, false ), diff --git a/includes/Classifai/Features/ImageCropping.php b/includes/Classifai/Features/ImageCropping.php index e90e0e028..777e4d0cd 100644 --- a/includes/Classifai/Features/ImageCropping.php +++ b/includes/Classifai/Features/ImageCropping.php @@ -273,10 +273,8 @@ public function attachment_data_meta_box( \WP_Post $post ) { /** * Display meta data. - * - * @param \WP_Post $post The post object. */ - public function attachment_data_meta_box_content( \WP_Post $post ) { + public function attachment_data_meta_box_content() { $smart_crop = get_transient( 'classifai_azure_computer_vision_image_cropping_latest_response' ) ? __( 'Regenerate smart thumbnail', 'classifai' ) : __( 'Create smart thumbnail', 'classifai' ); ?> diff --git a/includes/Classifai/Features/ImageTextExtraction.php b/includes/Classifai/Features/ImageTextExtraction.php index 9e5040d4f..90000ebc8 100644 --- a/includes/Classifai/Features/ImageTextExtraction.php +++ b/includes/Classifai/Features/ImageTextExtraction.php @@ -21,7 +21,7 @@ class ImageTextExtraction extends Feature { * * @var string */ - const ID = 'feature_image_to_text_generation'; + const ID = 'feature_image_to_text_generator'; /** * Constructor. diff --git a/includes/Classifai/Features/TitleGeneration.php b/includes/Classifai/Features/TitleGeneration.php index 157a86046..cbe0a7a51 100644 --- a/includes/Classifai/Features/TitleGeneration.php +++ b/includes/Classifai/Features/TitleGeneration.php @@ -384,7 +384,7 @@ public function sanitize_default_feature_settings( array $new_settings ): array $settings = $this->get_settings(); $new_settings['number_of_titles'] = sanitize_number_of_responses_field( 'number_of_titles', $new_settings, $settings ); - $new_settings['generate_title_prompt'] = sanitize_prompts( 'generate_excerpt_prompt', $new_settings ); + $new_settings['generate_title_prompt'] = sanitize_prompts( 'generate_title_prompt', $new_settings ); return $new_settings; } diff --git a/includes/Classifai/Helpers.php b/includes/Classifai/Helpers.php index 174cdc4be..e91ae6bb1 100644 --- a/includes/Classifai/Helpers.php +++ b/includes/Classifai/Helpers.php @@ -597,7 +597,7 @@ function get_default_prompt( array $prompts ): ?string { $prompt_data = array_filter( $prompts, function ( $prompt ) { - return isset( $prompt['default'] ) && ! $prompt['original']; + return isset( $prompt['default'] ) && $prompt['default'] && ! $prompt['original']; } ); diff --git a/includes/Classifai/Providers/Azure/ComputerVision.php b/includes/Classifai/Providers/Azure/ComputerVision.php index 1006f0540..8ae0c33ef 100644 --- a/includes/Classifai/Providers/Azure/ComputerVision.php +++ b/includes/Classifai/Providers/Azure/ComputerVision.php @@ -329,6 +329,10 @@ public function do_read_cron( string $operation_url, int $attachment_id ) { * @return array|WP_Error */ public function smart_crop_image( array $metadata, int $attachment_id ) { + if ( ! wp_attachment_is_image( $attachment_id ) ) { + return new WP_Error( 'invalid', esc_html__( 'This attachment can\'t be processed.', 'classifai' ) ); + } + $feature = new ImageCropping(); $settings = $feature->get_settings( static::ID ); @@ -379,6 +383,10 @@ public function smart_crop_image( array $metadata, int $attachment_id ) { * @return string|WP_Error */ public function ocr_processing( array $metadata = [], int $attachment_id = 0 ) { + if ( ! wp_attachment_is_image( $attachment_id ) ) { + return new WP_Error( 'invalid', esc_html__( 'This attachment can\'t be processed.', 'classifai' ) ); + } + $feature = new ImageTextExtraction(); $settings = $feature->get_settings( static::ID ); @@ -423,6 +431,10 @@ public function ocr_processing( array $metadata = [], int $attachment_id = 0 ) { * @return string|WP_Error */ public function generate_alt_tags( string $image_url, int $attachment_id ) { + if ( ! wp_attachment_is_image( $attachment_id ) ) { + return new WP_Error( 'invalid', esc_html__( 'This attachment can\'t be processed.', 'classifai' ) ); + } + $feature = new DescriptiveTextGenerator(); $rtn = ''; @@ -515,6 +527,10 @@ public function read_pdf( int $attachment_id ) { * @return array|WP_Error */ public function generate_image_tags( string $image_url, int $attachment_id ) { + if ( ! wp_attachment_is_image( $attachment_id ) ) { + return new WP_Error( 'invalid', esc_html__( 'This attachment can\'t be processed.', 'classifai' ) ); + } + $rtn = []; $feature = new ImageTagsGenerator(); $settings = $feature->get_settings( static::ID ); @@ -707,6 +723,10 @@ public function rest_endpoint_callback( $attachment_id, string $route_to_call = $metadata = wp_get_attachment_metadata( $attachment_id ); + if ( ! $metadata ) { + return new WP_Error( 'invalid', esc_html__( 'No valid metadata found.', 'classifai' ) ); + } + switch ( $route_to_call ) { case 'ocr': return $this->ocr_processing( $metadata, $attachment_id ); diff --git a/includes/Classifai/Providers/Watson/Helpers.php b/includes/Classifai/Providers/Watson/Helpers.php index a97263a7a..86942787a 100644 --- a/includes/Classifai/Providers/Watson/Helpers.php +++ b/includes/Classifai/Providers/Watson/Helpers.php @@ -207,16 +207,15 @@ function get_feature_enabled( string $classify_by ): bool { * @return float */ function get_feature_threshold( string $feature ): float { - $settings = get_plugin_settings( 'language_processing', 'Natural Language Understanding' ); - $threshold = 0; - - if ( ! empty( $settings ) && ! empty( $settings['features'] ) ) { - if ( ! empty( $settings['features'][ $feature . '_threshold' ] ) ) { - $threshold = filter_var( - $settings['features'][ $feature . '_threshold' ], - FILTER_VALIDATE_INT - ); - } + $classification_feature = new Classification(); + $settings = $classification_feature->get_settings( NLU::ID ); + $threshold = 0; + + if ( ! empty( $settings ) && ! empty( $settings[ $feature . '_threshold' ] ) ) { + $threshold = filter_var( + $settings[ $feature . '_threshold' ], + FILTER_VALIDATE_INT + ); } if ( empty( $threshold ) ) { @@ -237,7 +236,7 @@ function get_feature_threshold( string $feature ): float { * @hook classifai_feature_threshold * * @param {float} $threshold The threshold to use, expressed as a decimal between 0 and 1 inclusive. - * @param {string} $feature The feature in question. + * @param {string} $feature The feature in question. * * @return {float} The filtered threshold. */ diff --git a/includes/Classifai/Providers/Watson/NLU.php b/includes/Classifai/Providers/Watson/NLU.php index b4cd090ca..8a87ad5a4 100644 --- a/includes/Classifai/Providers/Watson/NLU.php +++ b/includes/Classifai/Providers/Watson/NLU.php @@ -118,7 +118,7 @@ public function render_provider_fields() { 'default_value' => $settings['username'], 'input_type' => 'text', 'large' => true, - 'class' => 'classifai-provider-field ' . ( $this->use_username_password() ? 'hidden' : '' ) . ' provider-scope-' . static::ID, // Important to add this. + 'class' => 'classifai-provider-field ' . ( $this->use_username_password() ? 'hide-username' : '' ) . ' provider-scope-' . static::ID, // Important to add this. ] ); diff --git a/package-lock.json b/package-lock.json index 0f5a32279..7a14297f8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -9,24 +9,25 @@ "version": "2.5.1", "license": "GPL-2.0-or-later", "dependencies": { - "@wordpress/icons": "^9.40.0", + "@wordpress/icons": "^9.41.0", "choices.js": "^10.2.0", "tippy.js": "^6.3.7" }, "devDependencies": { "@10up/cypress-wp-utils": "^0.2.0", - "@wordpress/env": "^9.1.0", - "@wordpress/scripts": "^27.0.0", - "cypress": "^13.6.3", + "@wordpress/env": "^9.2.0", + "@wordpress/scripts": "^27.1.0", + "cypress": "^13.6.4", "cypress-file-upload": "^5.0.8", - "cypress-mochawesome-reporter": "^3.8.0", + "cypress-mochawesome-reporter": "^3.8.1", "cypress-plugin-tab": "^1.0.5", "husky": "^8.0.3", "jsdoc": "^3.6.11", "lint-staged": "^15.2.0", + "mochawesome-json-to-md": "^0.7.2", "node-wp-i18n": "^1.2.7", "svg-react-loader": "^0.4.6", - "webpack": "^5.86.0", + "webpack": "^5.90.0", "webpack-cli": "^5.1.4", "wp-hookdoc": "^0.2.0" } @@ -186,9 +187,9 @@ } }, "node_modules/@babel/eslint-parser": { - "version": "7.23.3", - "resolved": "https://registry.npmjs.org/@babel/eslint-parser/-/eslint-parser-7.23.3.tgz", - "integrity": "sha512-9bTuNlyx7oSstodm1cR1bECj4fkiknsDa1YniISkJemMY3DGhJNYBECbe6QD/q54mp2J8VO66jW3/7uP//iFCw==", + "version": "7.23.9", + "resolved": "https://registry.npmjs.org/@babel/eslint-parser/-/eslint-parser-7.23.9.tgz", + "integrity": "sha512-xPndlO7qxiJbn0ATvfXQBjCS7qApc9xmKHArgI/FTEFxXas5dnjC/VqM37lfZun9dclRYcn+YQAr6uDFy0bB2g==", "dev": true, "dependencies": { "@nicolo-ribaudo/eslint-scope-5-internals": "5.1.1-v1", @@ -1721,16 +1722,16 @@ } }, "node_modules/@babel/plugin-transform-runtime": { - "version": "7.23.7", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.23.7.tgz", - "integrity": "sha512-fa0hnfmiXc9fq/weK34MUV0drz2pOL/vfKWvN7Qw127hiUPabFCUMgAbYWcchRzMJit4o5ARsK/s+5h0249pLw==", + "version": "7.23.9", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.23.9.tgz", + "integrity": "sha512-A7clW3a0aSjm3ONU9o2HAILSegJCYlEZmOhmBRReVtIpY/Z/p7yIZ+wR41Z+UipwdGuqwtID/V/dOdZXjwi9gQ==", "dev": true, "dependencies": { "@babel/helper-module-imports": "^7.22.15", "@babel/helper-plugin-utils": "^7.22.5", - "babel-plugin-polyfill-corejs2": "^0.4.7", - "babel-plugin-polyfill-corejs3": "^0.8.7", - "babel-plugin-polyfill-regenerator": "^0.5.4", + "babel-plugin-polyfill-corejs2": "^0.4.8", + "babel-plugin-polyfill-corejs3": "^0.9.0", + "babel-plugin-polyfill-regenerator": "^0.5.5", "semver": "^6.3.1" }, "engines": { @@ -1740,6 +1741,19 @@ "@babel/core": "^7.0.0-0" } }, + "node_modules/@babel/plugin-transform-runtime/node_modules/babel-plugin-polyfill-corejs3": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/babel-plugin-polyfill-corejs3/-/babel-plugin-polyfill-corejs3-0.9.0.tgz", + "integrity": "sha512-7nZPG1uzK2Ymhy/NbaOWTg3uibM2BmGASS4vHS4szRZAIR8R6GwA/xAujpdrXU5iyklrimWnLWU+BLF9suPTqg==", + "dev": true, + "dependencies": { + "@babel/helper-define-polyfill-provider": "^0.5.0", + "core-js-compat": "^3.34.0" + }, + "peerDependencies": { + "@babel/core": "^7.4.0 || ^8.0.0-0 <8.0.0" + } + }, "node_modules/@babel/plugin-transform-runtime/node_modules/semver": { "version": "6.3.1", "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", @@ -2844,9 +2858,9 @@ } }, "node_modules/@jridgewell/source-map": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.3.tgz", - "integrity": "sha512-b+fsZXeLYi9fEULmfBrhxn4IrPlINf8fiNarzTof004v3lFdntdwa9PF7vFJqm3mg7s+ScJMxXaE3Acp1irZcg==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/source-map/-/source-map-0.3.5.tgz", + "integrity": "sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==", "dev": true, "dependencies": { "@jridgewell/gen-mapping": "^0.3.0", @@ -2860,21 +2874,15 @@ "dev": true }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.18", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.18.tgz", - "integrity": "sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==", + "version": "0.3.22", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.22.tgz", + "integrity": "sha512-Wf963MzWtA2sjrNt+g18IAln9lKnlRp+K2eH4jjIoF1wYeq3aMREpG09xhlhdzS0EjwU7qmUJYangWa+151vZw==", "dev": true, "dependencies": { - "@jridgewell/resolve-uri": "3.1.0", - "@jridgewell/sourcemap-codec": "1.4.14" + "@jridgewell/resolve-uri": "^3.1.0", + "@jridgewell/sourcemap-codec": "^1.4.14" } }, - "node_modules/@jridgewell/trace-mapping/node_modules/@jridgewell/sourcemap-codec": { - "version": "1.4.14", - "resolved": "https://registry.npmjs.org/@jridgewell/sourcemap-codec/-/sourcemap-codec-1.4.14.tgz", - "integrity": "sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==", - "dev": true - }, "node_modules/@kwsites/file-exists": { "version": "1.1.1", "resolved": "https://registry.npmjs.org/@kwsites/file-exists/-/file-exists-1.1.1.tgz", @@ -3827,9 +3835,9 @@ } }, "node_modules/@types/estree": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.1.tgz", - "integrity": "sha512-LG4opVs2ANWZ1TJoKc937iMmNstM/d0ae1vNbnBvBhqCSezgVUOzcLCqbI5elV8Vy6WKwKjaqR+zO9VKirBBCA==", + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", + "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", "dev": true }, "node_modules/@types/express": { @@ -4242,16 +4250,16 @@ } }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.19.1.tgz", - "integrity": "sha512-roQScUGFruWod9CEyoV5KlCYrubC/fvG8/1zXuT0WTcxX87GnMMmnksMwSg99lo1xiKrBzw2icsJPMAw1OtKxg==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.20.0.tgz", + "integrity": "sha512-fTwGQUnjhoYHeSF6m5pWNkzmDDdsKELYrOBxhjMrofPqCkoC2k3B2wvGHFxa1CTIqkEn88nlW1HVMztjo2K8Hg==", "dev": true, "dependencies": { "@eslint-community/regexpp": "^4.5.1", - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/type-utils": "6.19.1", - "@typescript-eslint/utils": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/scope-manager": "6.20.0", + "@typescript-eslint/type-utils": "6.20.0", + "@typescript-eslint/utils": "6.20.0", + "@typescript-eslint/visitor-keys": "6.20.0", "debug": "^4.3.4", "graphemer": "^1.4.0", "ignore": "^5.2.4", @@ -4310,15 +4318,15 @@ "dev": true }, "node_modules/@typescript-eslint/parser": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.19.1.tgz", - "integrity": "sha512-WEfX22ziAh6pRE9jnbkkLGp/4RhTpffr2ZK5bJ18M8mIfA8A+k97U9ZyaXCEJRlmMHh7R9MJZWXp/r73DzINVQ==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.20.0.tgz", + "integrity": "sha512-bYerPDF/H5v6V76MdMYhjwmwgMA+jlPVqjSDq2cRqMi8bP5sR3Z+RLOiOMad3nsnmDVmn2gAFCyNgh/dIrfP/w==", "dev": true, "dependencies": { - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/typescript-estree": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/scope-manager": "6.20.0", + "@typescript-eslint/types": "6.20.0", + "@typescript-eslint/typescript-estree": "6.20.0", + "@typescript-eslint/visitor-keys": "6.20.0", "debug": "^4.3.4" }, "engines": { @@ -4338,13 +4346,13 @@ } }, "node_modules/@typescript-eslint/scope-manager": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.19.1.tgz", - "integrity": "sha512-4CdXYjKf6/6aKNMSly/BP4iCSOpvMmqtDzRtqFyyAae3z5kkqEjKndR5vDHL8rSuMIIWP8u4Mw4VxLyxZW6D5w==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.20.0.tgz", + "integrity": "sha512-p4rvHQRDTI1tGGMDFQm+GtxP1ZHyAh64WANVoyEcNMpaTFn3ox/3CcgtIlELnRfKzSs/DwYlDccJEtr3O6qBvA==", "dev": true, "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1" + "@typescript-eslint/types": "6.20.0", + "@typescript-eslint/visitor-keys": "6.20.0" }, "engines": { "node": "^16.0.0 || >=18.0.0" @@ -4355,13 +4363,13 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.19.1.tgz", - "integrity": "sha512-0vdyld3ecfxJuddDjACUvlAeYNrHP/pDeQk2pWBR2ESeEzQhg52DF53AbI9QCBkYE23lgkhLCZNkHn2hEXXYIg==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.20.0.tgz", + "integrity": "sha512-qnSobiJQb1F5JjN0YDRPHruQTrX7ICsmltXhkV536mp4idGAYrIyr47zF/JmkJtEcAVnIz4gUYJ7gOZa6SmN4g==", "dev": true, "dependencies": { - "@typescript-eslint/typescript-estree": "6.19.1", - "@typescript-eslint/utils": "6.19.1", + "@typescript-eslint/typescript-estree": "6.20.0", + "@typescript-eslint/utils": "6.20.0", "debug": "^4.3.4", "ts-api-utils": "^1.0.1" }, @@ -4382,9 +4390,9 @@ } }, "node_modules/@typescript-eslint/types": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.19.1.tgz", - "integrity": "sha512-6+bk6FEtBhvfYvpHsDgAL3uo4BfvnTnoge5LrrCj2eJN8g3IJdLTD4B/jK3Q6vo4Ql/Hoip9I8aB6fF+6RfDqg==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.20.0.tgz", + "integrity": "sha512-MM9mfZMAhiN4cOEcUOEx+0HmuaW3WBfukBZPCfwSqFnQy0grXYtngKCqpQN339X3RrwtzspWJrpbrupKYUSBXQ==", "dev": true, "engines": { "node": "^16.0.0 || >=18.0.0" @@ -4395,13 +4403,13 @@ } }, "node_modules/@typescript-eslint/typescript-estree": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.19.1.tgz", - "integrity": "sha512-aFdAxuhzBFRWhy+H20nYu19+Km+gFfwNO4TEqyszkMcgBDYQjmPJ61erHxuT2ESJXhlhrO7I5EFIlZ+qGR8oVA==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.20.0.tgz", + "integrity": "sha512-RnRya9q5m6YYSpBN7IzKu9FmLcYtErkDkc8/dKv81I9QiLLtVBHrjz+Ev/crAqgMNW2FCsoZF4g2QUylMnJz+g==", "dev": true, "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/types": "6.20.0", + "@typescript-eslint/visitor-keys": "6.20.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", @@ -4480,17 +4488,17 @@ "dev": true }, "node_modules/@typescript-eslint/utils": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.19.1.tgz", - "integrity": "sha512-JvjfEZuP5WoMqwh9SPAPDSHSg9FBHHGhjPugSRxu5jMfjvBpq5/sGTD+9M9aQ5sh6iJ8AY/Kk/oUYVEMAPwi7w==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.20.0.tgz", + "integrity": "sha512-/EKuw+kRu2vAqCoDwDCBtDRU6CTKbUmwwI7SH7AashZ+W+7o8eiyy6V2cdOqN49KsTcASWsC5QeghYuRDTyOOg==", "dev": true, "dependencies": { "@eslint-community/eslint-utils": "^4.4.0", "@types/json-schema": "^7.0.12", "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/typescript-estree": "6.19.1", + "@typescript-eslint/scope-manager": "6.20.0", + "@typescript-eslint/types": "6.20.0", + "@typescript-eslint/typescript-estree": "6.20.0", "semver": "^7.5.4" }, "engines": { @@ -4538,12 +4546,12 @@ "dev": true }, "node_modules/@typescript-eslint/visitor-keys": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.19.1.tgz", - "integrity": "sha512-gkdtIO+xSO/SmI0W68DBg4u1KElmIUo3vXzgHyGPs6cxgB0sa3TlptRAAE0hUY1hM6FcDKEv7aIwiTGm76cXfQ==", + "version": "6.20.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.20.0.tgz", + "integrity": "sha512-E8Cp98kRe4gKHjJD4NExXKz/zOJ1A2hhZc+IMVD6i7w4yjIvh6VyuRI0gRtxAsXtoC35uGMaQ9rjI2zJaXDEAw==", "dev": true, "dependencies": { - "@typescript-eslint/types": "6.19.1", + "@typescript-eslint/types": "6.20.0", "eslint-visitor-keys": "^3.4.1" }, "engines": { @@ -4763,23 +4771,23 @@ } }, "node_modules/@wordpress/api-fetch": { - "version": "6.46.0", - "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.46.0.tgz", - "integrity": "sha512-SimHPw57N8LyZpQB6dK5xq1Kn1WtqP/K27GjGwvxvkb+8xbVv0TI67AF9adsN4sZbOHIZJQwqvCTSGKhNttAvQ==", + "version": "6.47.0", + "resolved": "https://registry.npmjs.org/@wordpress/api-fetch/-/api-fetch-6.47.0.tgz", + "integrity": "sha512-NA/jWDXoVtJmiVBYhlxts2UrgKJpJM+zTGzLCfRQCZUzpJYm3LonB8x+uCQ78nEyxCY397Esod3jnbquYjOr0Q==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.49.0", - "@wordpress/url": "^3.50.0" + "@wordpress/i18n": "^4.50.0", + "@wordpress/url": "^3.51.0" }, "engines": { "node": ">=12" } }, "node_modules/@wordpress/babel-plugin-import-jsx-pragma": { - "version": "4.32.0", - "resolved": "https://registry.npmjs.org/@wordpress/babel-plugin-import-jsx-pragma/-/babel-plugin-import-jsx-pragma-4.32.0.tgz", - "integrity": "sha512-ie6p5VpUxTNMPQrHdCYEPddTzmDeFTQjFi3qq17set9WbRAMaOZ8jqQhSxms0NJi8Xa6wZM9TR2ZABAlg+FTeA==", + "version": "4.33.0", + "resolved": "https://registry.npmjs.org/@wordpress/babel-plugin-import-jsx-pragma/-/babel-plugin-import-jsx-pragma-4.33.0.tgz", + "integrity": "sha512-CjzruFKWgzU/mO/nnQJ2l9UlzZQpqS60UC6l2vNdJ9oD2nKHR5Oou6kNic3QhWDVJrBf2JUiJJ0TC280bykXmA==", "dev": true, "engines": { "node": ">=14" @@ -4789,9 +4797,9 @@ } }, "node_modules/@wordpress/babel-preset-default": { - "version": "7.33.0", - "resolved": "https://registry.npmjs.org/@wordpress/babel-preset-default/-/babel-preset-default-7.33.0.tgz", - "integrity": "sha512-/OonEa67xJdIn0ADWEd7AJtLhIGlYALKyc17RxTmI2Ojs0zLIQNbgAv1D/cuVguo0UKK9zsMZ9MBkhSKLF9A9Q==", + "version": "7.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/babel-preset-default/-/babel-preset-default-7.34.0.tgz", + "integrity": "sha512-yjFOllyTktFHtcIEgU3ghXBn8lItzr5mPLf0xdSpe0cHceFYL1hT1oprhgRL+olZweaO96Yfm0qUCCKQfJBWsA==", "dev": true, "dependencies": { "@babel/core": "^7.16.0", @@ -4800,9 +4808,9 @@ "@babel/preset-env": "^7.16.0", "@babel/preset-typescript": "^7.16.0", "@babel/runtime": "^7.16.0", - "@wordpress/babel-plugin-import-jsx-pragma": "^4.32.0", - "@wordpress/browserslist-config": "^5.32.0", - "@wordpress/warning": "^2.49.0", + "@wordpress/babel-plugin-import-jsx-pragma": "^4.33.0", + "@wordpress/browserslist-config": "^5.33.0", + "@wordpress/warning": "^2.50.0", "browserslist": "^4.21.10", "core-js": "^3.31.0", "react": "^18.2.0" @@ -4812,24 +4820,24 @@ } }, "node_modules/@wordpress/base-styles": { - "version": "4.40.0", - "resolved": "https://registry.npmjs.org/@wordpress/base-styles/-/base-styles-4.40.0.tgz", - "integrity": "sha512-A+HiyES4YjfbFhJAGrhCLB3QWomgWZR9wkgG7K9l6DD70/9Vd7t+go7jI1HJ1c9qGfBV0rmdQf/qNn89Aai1cg==", + "version": "4.41.0", + "resolved": "https://registry.npmjs.org/@wordpress/base-styles/-/base-styles-4.41.0.tgz", + "integrity": "sha512-MjPAZeAqvyskDXDp2wGZ0DjtYOQLOydI1WqVIZS4wnIdhsQWQD//VMeXgLrcmCzNyQg+iKTx3o+BzmXVTOD0+w==", "dev": true }, "node_modules/@wordpress/browserslist-config": { - "version": "5.32.0", - "resolved": "https://registry.npmjs.org/@wordpress/browserslist-config/-/browserslist-config-5.32.0.tgz", - "integrity": "sha512-LrL4Zg/abXYfVwwbx1caugz4J1GUL+6WNqVF1MZQVDm6CHdlpTEQOvvr/KEi9mN1UY2YoTlxZtUxzvNRTo2Fsg==", + "version": "5.33.0", + "resolved": "https://registry.npmjs.org/@wordpress/browserslist-config/-/browserslist-config-5.33.0.tgz", + "integrity": "sha512-dv1ZlpqGk8gaSBJPP/Z/1uOuxjtP0EBsHVKInLRu6FWLTJkK8rnCeC3xJT3/2TtJ0rasLC79RoytfhXTOODVwg==", "dev": true, "engines": { "node": ">=14" } }, "node_modules/@wordpress/dependency-extraction-webpack-plugin": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/@wordpress/dependency-extraction-webpack-plugin/-/dependency-extraction-webpack-plugin-5.0.0.tgz", - "integrity": "sha512-b3j4yCB5dR04rIbZ73iHN5hMXL4kMUUoApY36Zs8AAREHpgCDTPp5vNqc67zg2bcnpDEhMUZ28DISwrY4z7weg==", + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/@wordpress/dependency-extraction-webpack-plugin/-/dependency-extraction-webpack-plugin-5.1.0.tgz", + "integrity": "sha512-W2W+9JNAaGirAtGDSf83pjEKb63DLhgpJGgvMOpEPoRPtucgO6CCm3uMoNkJTpKoxJQ2tSZEymAhF/YdLm+ScQ==", "dev": true, "dependencies": { "json2php": "^0.0.7" @@ -4842,14 +4850,14 @@ } }, "node_modules/@wordpress/e2e-test-utils-playwright": { - "version": "0.17.0", - "resolved": "https://registry.npmjs.org/@wordpress/e2e-test-utils-playwright/-/e2e-test-utils-playwright-0.17.0.tgz", - "integrity": "sha512-WuyorK1PL4r0LtxdhwF8u31s/O7+reuU906dnM3pu6SKSPsyfhXi8O1hgQO4/VASooHygUbsn7PW0GaDdCamOA==", + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/@wordpress/e2e-test-utils-playwright/-/e2e-test-utils-playwright-0.18.0.tgz", + "integrity": "sha512-Z8uH1dUzy/STQjOU6eb9nquVK4RC1rUx0gXY/GN1IVNDJvGN/yJxT/gNKmfiL7KpmHvNp2Q5M4bnUT9uiNcM+Q==", "dev": true, "dependencies": { - "@wordpress/api-fetch": "^6.46.0", - "@wordpress/keycodes": "^3.49.0", - "@wordpress/url": "^3.50.0", + "@wordpress/api-fetch": "^6.47.0", + "@wordpress/keycodes": "^3.50.0", + "@wordpress/url": "^3.51.0", "change-case": "^4.1.2", "form-data": "^4.0.0", "get-port": "^5.1.1", @@ -4879,14 +4887,14 @@ } }, "node_modules/@wordpress/element": { - "version": "5.26.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.26.0.tgz", - "integrity": "sha512-pYZ2OsFgDN00amTxPoC7BtlkVtVBeLS/Y1+P1Mlu0CX+gHDP0Il9SUaLVEIAewLnZMN+O3ph3H5nfR0yKkSnAA==", + "version": "5.27.0", + "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-5.27.0.tgz", + "integrity": "sha512-IA5LTAfx5bDNXULPmctcNb/04i4JcnIReG0RAuPgrZ8lbMZWUxGFymh10PEQjs7ZJ++qGsI6E+6JISpjkRaDQQ==", "dependencies": { "@babel/runtime": "^7.16.0", "@types/react": "^18.0.21", "@types/react-dom": "^18.0.6", - "@wordpress/escape-html": "^2.49.0", + "@wordpress/escape-html": "^2.50.0", "change-case": "^4.1.2", "is-plain-object": "^5.0.0", "react": "^18.2.0", @@ -4897,9 +4905,9 @@ } }, "node_modules/@wordpress/env": { - "version": "9.1.0", - "resolved": "https://registry.npmjs.org/@wordpress/env/-/env-9.1.0.tgz", - "integrity": "sha512-IkPeYPczWmosqyulVHiu/fRQg5Q0PenCimbLieksif7ETFH8hUSwvsiWfvC/Sx//MzIB3/yGaVVodEzZnyJGgA==", + "version": "9.2.0", + "resolved": "https://registry.npmjs.org/@wordpress/env/-/env-9.2.0.tgz", + "integrity": "sha512-2gl65WYbkuTjnW2SHKjeqdpLTgnPc/xVvFiwG+2p/RJwDHSuw1xXSdFqFUh3+wC/4cuXy9b2ZBm/SYsBoc8DDw==", "dev": true, "dependencies": { "chalk": "^4.0.0", @@ -4920,9 +4928,9 @@ } }, "node_modules/@wordpress/escape-html": { - "version": "2.49.0", - "resolved": "https://registry.npmjs.org/@wordpress/escape-html/-/escape-html-2.49.0.tgz", - "integrity": "sha512-JmVm6IWr5EhXU5m7LCwMOiSv90qJU1l8Q2xlBCQ+0bIPcWRjsHX9pFKDOJvQ6D55W/CTGO1GQk50uolktTeTtw==", + "version": "2.50.0", + "resolved": "https://registry.npmjs.org/@wordpress/escape-html/-/escape-html-2.50.0.tgz", + "integrity": "sha512-hBvoMCEZocziZDGCmBanSO+uupnd054mxd7FQ6toQ4UnsZ4JwXSmEC72W2Ed+cRGB1DeJDD0dY9iC0b4xkumsQ==", "dependencies": { "@babel/runtime": "^7.16.0" }, @@ -4931,16 +4939,16 @@ } }, "node_modules/@wordpress/eslint-plugin": { - "version": "17.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/eslint-plugin/-/eslint-plugin-17.6.0.tgz", - "integrity": "sha512-piANQS5eaSPmpzPXdNZdXbKcHjAyXbuHeUd9ctVA+6sOMVay70+ICQj7Isu4o61Wv43KtxugQoa2PSBqVtrRKA==", + "version": "17.7.0", + "resolved": "https://registry.npmjs.org/@wordpress/eslint-plugin/-/eslint-plugin-17.7.0.tgz", + "integrity": "sha512-JSFaCogE0WlZpl0SV4q8DK8G6jwDjEzXRzOsgesWilea4OuVp1KxCamkddTorRNM3QAbjrGuPJ4NYaGrNG9QsA==", "dev": true, "dependencies": { "@babel/eslint-parser": "^7.16.0", "@typescript-eslint/eslint-plugin": "^6.4.1", "@typescript-eslint/parser": "^6.4.1", - "@wordpress/babel-preset-default": "^7.33.0", - "@wordpress/prettier-config": "^3.6.0", + "@wordpress/babel-preset-default": "^7.34.0", + "@wordpress/prettier-config": "^3.7.0", "cosmiconfig": "^7.0.0", "eslint-config-prettier": "^8.3.0", "eslint-plugin-import": "^2.25.2", @@ -5001,9 +5009,9 @@ } }, "node_modules/@wordpress/hooks": { - "version": "3.49.0", - "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.49.0.tgz", - "integrity": "sha512-GH546Jg8u/rw9I3fsvAhidwt8rUFNmkdXGByIPGsN3R6y+QwWMXPzsnoYdFmFOmDK9gOGCRDe5bXHikoWnaiKA==", + "version": "3.50.0", + "resolved": "https://registry.npmjs.org/@wordpress/hooks/-/hooks-3.50.0.tgz", + "integrity": "sha512-YIhwT1y0ss7Byfz46NBx08EUmXzWMu+g5DCY7FMuDNhwxSEoZMB8edKMiwNmFk4mFKBCnXM1d5FeONUPIUkJwg==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0" @@ -5013,13 +5021,13 @@ } }, "node_modules/@wordpress/i18n": { - "version": "4.49.0", - "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.49.0.tgz", - "integrity": "sha512-8aZmmRfOHzS/3pMWg+4f6QlPci0wK5V+PDllAwtwFFrXgc0pmk8VXu7Quajh1tiVoIQDCZpK6h1sqa+qrCLpZg==", + "version": "4.50.0", + "resolved": "https://registry.npmjs.org/@wordpress/i18n/-/i18n-4.50.0.tgz", + "integrity": "sha512-FkA2se6HMQm4eFC+/kTWvWQqs51VxpZuvY2MlWUp/L1r1d/dMBHXu049x86+/+6yk3ZNqiK5h6j6Z76dvPHZ4w==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/hooks": "^3.49.0", + "@wordpress/hooks": "^3.50.0", "gettext-parser": "^1.3.1", "memize": "^2.1.0", "sprintf-js": "^1.1.1", @@ -5049,22 +5057,22 @@ "dev": true }, "node_modules/@wordpress/icons": { - "version": "9.40.0", - "resolved": "https://registry.npmjs.org/@wordpress/icons/-/icons-9.40.0.tgz", - "integrity": "sha512-NSbhur14Ypr+hbgp848430cmk2AHZ7E2e9zvj8917ZjhrVCD7zYT590hOspswJZEaFxJdY3QSnegGiBSI/MacQ==", + "version": "9.41.0", + "resolved": "https://registry.npmjs.org/@wordpress/icons/-/icons-9.41.0.tgz", + "integrity": "sha512-L4fp9ZdxGBpMk3o2YqABgiPHNoHyu9Enid7JNkCdWP8iUgk7dEiDvo/XoiWPTAeNbF6W8Nqu54635mq01es0NQ==", "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/element": "^5.26.0", - "@wordpress/primitives": "^3.47.0" + "@wordpress/element": "^5.27.0", + "@wordpress/primitives": "^3.48.0" }, "engines": { "node": ">=12" } }, "node_modules/@wordpress/jest-console": { - "version": "7.20.0", - "resolved": "https://registry.npmjs.org/@wordpress/jest-console/-/jest-console-7.20.0.tgz", - "integrity": "sha512-EXexYwBLaJSpSCUwpQeSqjJ9G7KDkzH+oCfiZp4ZYuemmCaJFOn8/HOLwfLU0o7i0bfYFAjt8lSVCr5HiYY0AA==", + "version": "7.21.0", + "resolved": "https://registry.npmjs.org/@wordpress/jest-console/-/jest-console-7.21.0.tgz", + "integrity": "sha512-o2vZRlwwJ6WoxRwnFFT5iZzfdc2d9MZvrtwB093RWPNcyK5qVtApji4VN/ieHijB4bjEHGalm0UKfKpt0EDlUQ==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0", @@ -5078,12 +5086,12 @@ } }, "node_modules/@wordpress/jest-preset-default": { - "version": "11.20.0", - "resolved": "https://registry.npmjs.org/@wordpress/jest-preset-default/-/jest-preset-default-11.20.0.tgz", - "integrity": "sha512-3x2ua/rc0540zfLOrHbfdrEOwS5xWPbX5/f2LUyM2T6zzmhXrnqG2WFdhftFFLAUhC8cbxuy1WNnrzgjUxGeDQ==", + "version": "11.21.0", + "resolved": "https://registry.npmjs.org/@wordpress/jest-preset-default/-/jest-preset-default-11.21.0.tgz", + "integrity": "sha512-XAztKOROu02iBsz+Qosv/RYuPWB1XwwlU+FiA5Y68tRztrqFy4b/il+DFg4Jue/zXF7UECWUvosd5ow/GmKa6Q==", "dev": true, "dependencies": { - "@wordpress/jest-console": "^7.20.0", + "@wordpress/jest-console": "^7.21.0", "babel-jest": "^29.6.2" }, "engines": { @@ -5095,22 +5103,22 @@ } }, "node_modules/@wordpress/keycodes": { - "version": "3.49.0", - "resolved": "https://registry.npmjs.org/@wordpress/keycodes/-/keycodes-3.49.0.tgz", - "integrity": "sha512-Hg+kUTV/ti+CyG4+D3dmRFMmrE45E2QEv7ZKaeIf+t1wlafekLSDwIpdF7e68HxEMmZSzHmLm7bHqQTNjxAoKQ==", + "version": "3.50.0", + "resolved": "https://registry.npmjs.org/@wordpress/keycodes/-/keycodes-3.50.0.tgz", + "integrity": "sha512-ykWpyCbgwcaT8i5kSfotYtd2oOHyMDpWEYR73InYrzEhl7pnS3wD7hi/KfeKLvMfYhbysUXlCVr6q/oH+qK/DQ==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/i18n": "^4.49.0" + "@wordpress/i18n": "^4.50.0" }, "engines": { "node": ">=12" } }, "node_modules/@wordpress/npm-package-json-lint-config": { - "version": "4.34.0", - "resolved": "https://registry.npmjs.org/@wordpress/npm-package-json-lint-config/-/npm-package-json-lint-config-4.34.0.tgz", - "integrity": "sha512-mknDw+d5HIfx/1DyrhkbLJNu8XsmUEjc1SsYSgF2XCP20/khpO7YOi0LWn9uQ2QXWZrlhMc7JKSSOcTs0aLphQ==", + "version": "4.35.0", + "resolved": "https://registry.npmjs.org/@wordpress/npm-package-json-lint-config/-/npm-package-json-lint-config-4.35.0.tgz", + "integrity": "sha512-QmkhYM4/s+2r3RuolVRRmoUa5o3lFgcHA6I3A9akaSVGZr//4p2p+iXOGmNub9njgGlj7j8SAPN8GUsCO/VqZQ==", "dev": true, "engines": { "node": ">=14" @@ -5120,12 +5128,12 @@ } }, "node_modules/@wordpress/postcss-plugins-preset": { - "version": "4.33.0", - "resolved": "https://registry.npmjs.org/@wordpress/postcss-plugins-preset/-/postcss-plugins-preset-4.33.0.tgz", - "integrity": "sha512-RqKNf8XQTdae0cXO11l6mBw+A3IOEO9dd4sD70g15e4IltrbwuxqwOT5k9muNteUszTCOQKgWgD8gp1KM2/lvQ==", + "version": "4.34.0", + "resolved": "https://registry.npmjs.org/@wordpress/postcss-plugins-preset/-/postcss-plugins-preset-4.34.0.tgz", + "integrity": "sha512-OLQBSLE2q11Ik+WdcO2QfGr/O4X/zJYOGXNsychx/EaMamLzJInFcRL6kGbPX41zPINhadq5x2vFIZI2EC+Uyg==", "dev": true, "dependencies": { - "@wordpress/base-styles": "^4.40.0", + "@wordpress/base-styles": "^4.41.0", "autoprefixer": "^10.2.5" }, "engines": { @@ -5136,9 +5144,9 @@ } }, "node_modules/@wordpress/prettier-config": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/@wordpress/prettier-config/-/prettier-config-3.6.0.tgz", - "integrity": "sha512-51GuCeeEGOi4qsMpzGFBmKbqEUKLqWj3eZDIwATymUaHsJPx9oT93dlIP97MqKIaWjxlhxCMt5RjxcCNT7Pckw==", + "version": "3.7.0", + "resolved": "https://registry.npmjs.org/@wordpress/prettier-config/-/prettier-config-3.7.0.tgz", + "integrity": "sha512-JRTc5p7UxtcPkqdSDXSFJoJnVuS510uiRVz8anXEl5nuOx5p+SJAzi9QPrxTgOE8bN3wRABH4eIhfOcta4CFdg==", "dev": true, "engines": { "node": ">=14" @@ -5148,12 +5156,12 @@ } }, "node_modules/@wordpress/primitives": { - "version": "3.47.0", - "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.47.0.tgz", - "integrity": "sha512-ho4XrOI9PTGmQhgEYHuRBfgnPzPuq2zXJpQa2GCrbhm4fojLmZ7oWVBzrL2cGtFGD6dJhY3dbY+l+rNs97A2TA==", + "version": "3.48.0", + "resolved": "https://registry.npmjs.org/@wordpress/primitives/-/primitives-3.48.0.tgz", + "integrity": "sha512-uBoMxpl+FiZF6aRXH/+Hwol4EAL6QqlNSaGF1IzEwklFzdRF1m5wTM4vh21w8Bq7lgxiuAqyueY7X5u32v+zPw==", "dependencies": { "@babel/runtime": "^7.16.0", - "@wordpress/element": "^5.26.0", + "@wordpress/element": "^5.27.0", "classnames": "^2.3.1" }, "engines": { @@ -5161,24 +5169,24 @@ } }, "node_modules/@wordpress/scripts": { - "version": "27.0.0", - "resolved": "https://registry.npmjs.org/@wordpress/scripts/-/scripts-27.0.0.tgz", - "integrity": "sha512-WXZPvgOaFCK1ZBov99lOOWE5Nl/eDMGTnx0sTsE1FcgAOVgKwaKvDCsRWYqYmf1O3aAhud0+YPIJyewbIHOQdQ==", + "version": "27.1.0", + "resolved": "https://registry.npmjs.org/@wordpress/scripts/-/scripts-27.1.0.tgz", + "integrity": "sha512-jewyOxqaNrsct5R1NXv2lT8CA70vzrvpdZHYERCcH9LzKuvrcc32Telm9Jqso6ay1ZgHeIbjHSCd2+r2sBG7hw==", "dev": true, "dependencies": { "@babel/core": "^7.16.0", "@pmmmwh/react-refresh-webpack-plugin": "^0.5.11", "@svgr/webpack": "^8.0.1", - "@wordpress/babel-preset-default": "^7.33.0", - "@wordpress/browserslist-config": "^5.32.0", - "@wordpress/dependency-extraction-webpack-plugin": "^5.0.0", - "@wordpress/e2e-test-utils-playwright": "^0.17.0", - "@wordpress/eslint-plugin": "^17.6.0", - "@wordpress/jest-preset-default": "^11.20.0", - "@wordpress/npm-package-json-lint-config": "^4.34.0", - "@wordpress/postcss-plugins-preset": "^4.33.0", - "@wordpress/prettier-config": "^3.6.0", - "@wordpress/stylelint-config": "^21.32.0", + "@wordpress/babel-preset-default": "^7.34.0", + "@wordpress/browserslist-config": "^5.33.0", + "@wordpress/dependency-extraction-webpack-plugin": "^5.1.0", + "@wordpress/e2e-test-utils-playwright": "^0.18.0", + "@wordpress/eslint-plugin": "^17.7.0", + "@wordpress/jest-preset-default": "^11.21.0", + "@wordpress/npm-package-json-lint-config": "^4.35.0", + "@wordpress/postcss-plugins-preset": "^4.34.0", + "@wordpress/prettier-config": "^3.7.0", + "@wordpress/stylelint-config": "^21.33.0", "adm-zip": "^0.5.9", "babel-jest": "^29.6.2", "babel-loader": "^8.2.3", @@ -5239,9 +5247,9 @@ } }, "node_modules/@wordpress/stylelint-config": { - "version": "21.32.0", - "resolved": "https://registry.npmjs.org/@wordpress/stylelint-config/-/stylelint-config-21.32.0.tgz", - "integrity": "sha512-cmrzU55alv+OZu1fXBC2eZGgJIUwyD47TSDDP7l0o9yF6D/w0am7FxC9ungk/S2uK1oatN05nIPsFSTkuHQSzg==", + "version": "21.33.0", + "resolved": "https://registry.npmjs.org/@wordpress/stylelint-config/-/stylelint-config-21.33.0.tgz", + "integrity": "sha512-DwjXrjRBva0tkYILvDV7rjl3VaKXxvchlxnFfFs6l2DWL/Qo31CJ+f2rVw4XSWuuWxY1EsyIn9tOBS9URloWTQ==", "dev": true, "dependencies": { "stylelint-config-recommended": "^6.0.0", @@ -5255,9 +5263,9 @@ } }, "node_modules/@wordpress/url": { - "version": "3.50.0", - "resolved": "https://registry.npmjs.org/@wordpress/url/-/url-3.50.0.tgz", - "integrity": "sha512-+YQzsPim5Zx55o/y9urtd0CKANUgwqZSdUNjDWYZ/1CWxtLLzPgQJOabtl79hG2yjrKvjDe9PrDPff18bCmG5A==", + "version": "3.51.0", + "resolved": "https://registry.npmjs.org/@wordpress/url/-/url-3.51.0.tgz", + "integrity": "sha512-OjucjlP1763gfKbe8lv/k3RCisyX8AfNBrhASk7JqxAj6rFhb1ZZO7YmAgB2m+WoGB5v7fkOli0FZyDqISdYyg==", "dev": true, "dependencies": { "@babel/runtime": "^7.16.0", @@ -5268,9 +5276,9 @@ } }, "node_modules/@wordpress/warning": { - "version": "2.49.0", - "resolved": "https://registry.npmjs.org/@wordpress/warning/-/warning-2.49.0.tgz", - "integrity": "sha512-W2Nj9Nj0o2udPLf8jfGijRff3lzQgPOiLZcN4LFUPT6yyb9MxvNIg7ZVTBJL2TB78+KQKGrIH4ERjV5WyDRoEQ==", + "version": "2.50.0", + "resolved": "https://registry.npmjs.org/@wordpress/warning/-/warning-2.50.0.tgz", + "integrity": "sha512-y7Zf48roDfiPgbRAWGXDwN3C8sfbEdneGq+HvXCW6rIeGYnDLdEkpX9i7RfultkFFPVeSP3FpMKVMkto2nbqzA==", "dev": true, "engines": { "node": ">=12" @@ -7539,12 +7547,12 @@ } }, "node_modules/core-js-compat": { - "version": "3.33.3", - "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.33.3.tgz", - "integrity": "sha512-cNzGqFsh3Ot+529GIXacjTJ7kegdt5fPXxCBVS1G0iaZpuo/tBz399ymceLJveQhFFZ8qThHiP3fzuoQjKN2ow==", + "version": "3.35.1", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.35.1.tgz", + "integrity": "sha512-sftHa5qUJY3rs9Zht1WEnmkvXputCyDBczPnr7QDgL8n3qrF3CMXY4VPSYtOLLiOUJcah2WNXREd48iOl6mQIw==", "dev": true, "dependencies": { - "browserslist": "^4.22.1" + "browserslist": "^4.22.2" }, "funding": { "type": "opencollective", @@ -7967,9 +7975,9 @@ } }, "node_modules/cypress": { - "version": "13.6.3", - "resolved": "https://registry.npmjs.org/cypress/-/cypress-13.6.3.tgz", - "integrity": "sha512-d/pZvgwjAyZsoyJ3FOsJT5lDsqnxQ/clMqnNc++rkHjbkkiF2h9s0JsZSyyH4QXhVFW3zPFg82jD25roFLOdZA==", + "version": "13.6.4", + "resolved": "https://registry.npmjs.org/cypress/-/cypress-13.6.4.tgz", + "integrity": "sha512-pYJjCfDYB+hoOoZuhysbbYhEmNW7DEDsqn+ToCLwuVowxUXppIWRr7qk4TVRIU471ksfzyZcH+mkoF0CQUKnpw==", "dev": true, "hasInstallScript": true, "dependencies": { @@ -8036,9 +8044,9 @@ } }, "node_modules/cypress-mochawesome-reporter": { - "version": "3.8.0", - "resolved": "https://registry.npmjs.org/cypress-mochawesome-reporter/-/cypress-mochawesome-reporter-3.8.0.tgz", - "integrity": "sha512-awdOlkWmB0xGBsO8iitOAJi30uSTtxvM+S6bq03Xw3DP5nMUdYlbvmLbetG0bkMPFkv1wn5ogQuw58Jv603n2A==", + "version": "3.8.1", + "resolved": "https://registry.npmjs.org/cypress-mochawesome-reporter/-/cypress-mochawesome-reporter-3.8.1.tgz", + "integrity": "sha512-oqtyDE4OOd5D7uas4+ljIb3vkO4gHWErhWKV7TbNF20YweiHWmzuOmS6L0MGk3J6IF6VbfO4h86kSa0sNsaKUg==", "dev": true, "dependencies": { "commander": "^10.0.1", @@ -15562,6 +15570,19 @@ "mocha": ">=7" } }, + "node_modules/mochawesome-json-to-md": { + "version": "0.7.2", + "resolved": "https://registry.npmjs.org/mochawesome-json-to-md/-/mochawesome-json-to-md-0.7.2.tgz", + "integrity": "sha512-dxh+o73bhC6nEph6fNky9wy35R+2oK3ueXwAlJ/COAanlFgu8GuvGzQ00VNO4PPYhYGDsO4vbt4QTcMA3lv25g==", + "deprecated": "馃檶 Thanks for using it. We recommend upgrading to the newer version, 1.x.x. Check out https://www.npmjs.com/package/mochawesome-json-to-md for details.", + "dev": true, + "dependencies": { + "yargs": "^17.0.1" + }, + "bin": { + "mochawesome-json-to-md": "index.js" + } + }, "node_modules/mochawesome-merge": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/mochawesome-merge/-/mochawesome-merge-4.3.0.tgz", @@ -16107,9 +16128,9 @@ } }, "node_modules/npm-package-json-lint/node_modules/jsonc-parser": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.0.tgz", - "integrity": "sha512-gfFQZrcTc8CnKXp6Y4/CBT3fTc0OVuDofpre4aEeEpSBPV5X5v4+Vmx+8snU7RLPrNHPKSgLxGo9YuQzz20o+w==", + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/jsonc-parser/-/jsonc-parser-3.2.1.tgz", + "integrity": "sha512-AilxAyFOAcK5wA1+LeaySVBrHsGQvUFCDWXKpZjzaL0PqW+xfBOttn8GNtWKFWqneyMZj41MWF9Kl6iPWLwgOA==", "dev": true }, "node_modules/npm-package-json-lint/node_modules/lru-cache": { @@ -19553,9 +19574,9 @@ } }, "node_modules/spdx-exceptions": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", - "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.4.0.tgz", + "integrity": "sha512-hcjppoJ68fhxA/cjbN4T8N6uCUejN8yFw69ttpqtBeCbF3u13n7mb31NB9jKwGTTWWnt9IbRA/mf1FprYS8wfw==", "dev": true }, "node_modules/spdx-expression-parse": { @@ -20365,9 +20386,9 @@ } }, "node_modules/terser": { - "version": "5.17.7", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.17.7.tgz", - "integrity": "sha512-/bi0Zm2C6VAexlGgLlVxA0P2lru/sdLyfCVaRMfKVo9nWxbmz7f/sD8VPybPeSUJaJcwmCJis9pBIhcVcG1QcQ==", + "version": "5.27.0", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.27.0.tgz", + "integrity": "sha512-bi1HRwVRskAjheeYl291n3JC4GgO/Ty4z1nVs5AAsmonJulGxpSektecnNedrwK9C7vpvVtcX3cw00VSLt7U2A==", "dev": true, "dependencies": { "@jridgewell/source-map": "^0.3.3", @@ -20383,16 +20404,16 @@ } }, "node_modules/terser-webpack-plugin": { - "version": "5.3.9", - "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.9.tgz", - "integrity": "sha512-ZuXsqE07EcggTWQjXUj+Aot/OMcD0bMKGgF63f7UxYcu5/AJF53aIpK1YoP5xR9l6s/Hy2b+t1AM0bLNPRuhwA==", + "version": "5.3.10", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-5.3.10.tgz", + "integrity": "sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==", "dev": true, "dependencies": { - "@jridgewell/trace-mapping": "^0.3.17", + "@jridgewell/trace-mapping": "^0.3.20", "jest-worker": "^27.4.5", "schema-utils": "^3.1.1", "serialize-javascript": "^6.0.1", - "terser": "^5.16.8" + "terser": "^5.26.0" }, "engines": { "node": ">= 10.13.0" @@ -21305,9 +21326,9 @@ } }, "node_modules/web-vitals": { - "version": "3.5.1", - "resolved": "https://registry.npmjs.org/web-vitals/-/web-vitals-3.5.1.tgz", - "integrity": "sha512-xQ9lvIpfLxUj0eSmT79ZjRoU5wIRfIr7pNukL7ZE4EcWZSmfZQqOlhuAGfkVa3EFmzPHZhWhXfm2i5ys+THVPg==", + "version": "3.5.2", + "resolved": "https://registry.npmjs.org/web-vitals/-/web-vitals-3.5.2.tgz", + "integrity": "sha512-c0rhqNcHXRkY/ogGDJQxZ9Im9D19hDihbzSQJrsioex+KnFgmMzBiy57Z1EjkhX/+OjyBpclDCzz2ITtjokFmg==", "dev": true }, "node_modules/webidl-conversions": { @@ -21320,19 +21341,19 @@ } }, "node_modules/webpack": { - "version": "5.89.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.89.0.tgz", - "integrity": "sha512-qyfIC10pOr70V+jkmud8tMfajraGCZMBWJtrmuBymQKCrLTRejBI8STDp1MCyZu/QTdZSeacCQYpYNQVOzX5kw==", + "version": "5.90.0", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.90.0.tgz", + "integrity": "sha512-bdmyXRCXeeNIePv6R6tGPyy20aUobw4Zy8r0LUS2EWO+U+Ke/gYDgsCh7bl5rB6jPpr4r0SZa6dPxBxLooDT3w==", "dev": true, "dependencies": { "@types/eslint-scope": "^3.7.3", - "@types/estree": "^1.0.0", + "@types/estree": "^1.0.5", "@webassemblyjs/ast": "^1.11.5", "@webassemblyjs/wasm-edit": "^1.11.5", "@webassemblyjs/wasm-parser": "^1.11.5", "acorn": "^8.7.1", "acorn-import-assertions": "^1.9.0", - "browserslist": "^4.14.5", + "browserslist": "^4.21.10", "chrome-trace-event": "^1.0.2", "enhanced-resolve": "^5.15.0", "es-module-lexer": "^1.2.1", @@ -21346,7 +21367,7 @@ "neo-async": "^2.6.2", "schema-utils": "^3.2.0", "tapable": "^2.1.1", - "terser-webpack-plugin": "^5.3.7", + "terser-webpack-plugin": "^5.3.10", "watchpack": "^2.4.0", "webpack-sources": "^3.2.3" }, diff --git a/package.json b/package.json index 3447e38d7..93136f795 100644 --- a/package.json +++ b/package.json @@ -37,23 +37,24 @@ }, "devDependencies": { "@10up/cypress-wp-utils": "^0.2.0", - "@wordpress/env": "^9.1.0", - "@wordpress/scripts": "^27.0.0", - "cypress": "^13.6.3", + "@wordpress/env": "^9.2.0", + "@wordpress/scripts": "^27.1.0", + "cypress": "^13.6.4", "cypress-file-upload": "^5.0.8", - "cypress-mochawesome-reporter": "^3.8.0", + "cypress-mochawesome-reporter": "^3.8.1", "cypress-plugin-tab": "^1.0.5", "husky": "^8.0.3", "jsdoc": "^3.6.11", "lint-staged": "^15.2.0", + "mochawesome-json-to-md": "^0.7.2", "node-wp-i18n": "^1.2.7", "svg-react-loader": "^0.4.6", - "webpack": "^5.86.0", + "webpack": "^5.90.0", "webpack-cli": "^5.1.4", "wp-hookdoc": "^0.2.0" }, "dependencies": { - "@wordpress/icons": "^9.40.0", + "@wordpress/icons": "^9.41.0", "choices.js": "^10.2.0", "tippy.js": "^6.3.7" } diff --git a/src/js/admin.js b/src/js/admin.js index 8e8a27f6c..a2d76c721 100644 --- a/src/js/admin.js +++ b/src/js/admin.js @@ -64,9 +64,9 @@ document.addEventListener( 'DOMContentLoaded', function () { $toggler.addEventListener( 'click', ( e ) => { e.preventDefault(); - $userFieldWrapper.classList.toggle( 'hidden' ); + $userFieldWrapper.classList.toggle( 'hide-username' ); - if ( $userFieldWrapper.classList.contains( 'hidden' ) ) { + if ( $userFieldWrapper.classList.contains( 'hide-username' ) ) { $toggler.innerText = ClassifAI.use_password; $passwordFieldTitle.innerText = ClassifAI.api_key; $userField.value = 'apikey'; diff --git a/src/scss/admin.scss b/src/scss/admin.scss index af39b2ac2..62ef171e2 100644 --- a/src/scss/admin.scss +++ b/src/scss/admin.scss @@ -367,6 +367,10 @@ input.classifai-button { margin-bottom: 4px; } + .hide-username { + display: none; + } + .components-form-token-field__input-container input[type=text].components-form-token-field__input { height: auto; font-size: 14px; diff --git a/tests/Classifai/Providers/Azure/SmartCroppingTest.php b/tests/Classifai/Providers/Azure/SmartCroppingTest.php index 12e781a30..c9ae44a9a 100644 --- a/tests/Classifai/Providers/Azure/SmartCroppingTest.php +++ b/tests/Classifai/Providers/Azure/SmartCroppingTest.php @@ -155,22 +155,29 @@ public function test_get_cropped_thumbnail() { $with_filter_cb = function() use ( $attachment ) { - // Get the uploaded image url - $cropped_thumbnail_url = $this->get_smart_cropping()->get_cropped_thumbnail( + // Get the uploaded image data. + $cropped_thumbnail_data = $this->get_smart_cropping()->get_cropped_thumbnail( $attachment, wp_get_attachment_metadata( $attachment )['sizes']['thumbnail'], ); - // Strip out everything before /wp-content/ because it won't match. - $prepped_url = substr( $cropped_thumbnail_url, strpos( $cropped_thumbnail_url , '/wp-content/' ) ); + $cropped_images['thumbnail'] = [ + 'width' => 150, + 'height' => 150, + 'data' => $cropped_thumbnail_data, + ]; - // TODO: fix this - if ( false ) { - $this->assertEquals( - sprintf( '%s/33772-150x150.jpg', wp_upload_dir()['path'] ), - $cropped_thumbnail_url - ); - } + $meta = ( new \Classifai\Features\ImageCropping() )->save( $cropped_images, $attachment ); + + $this->assertEquals( + file_get_contents( DIR_TESTDATA .'/images/33772.jpg' ), + $cropped_thumbnail_data + ); + + $this->assertEquals( + '33772-150x150.jpg', + $meta['sizes']['thumbnail']['file'] + ); }; $this->with_http_request_filter( $with_filter_cb ); diff --git a/tests/cypress/config.config.js b/tests/cypress/config.config.js index d9fee0593..f56d48452 100644 --- a/tests/cypress/config.config.js +++ b/tests/cypress/config.config.js @@ -1,6 +1,8 @@ const { defineConfig } = require( 'cypress' ); module.exports = defineConfig( { + viewportWidth: 1280, + viewportHeight: 1280, chromeWebSecurity: false, fixturesFolder: __dirname + '/fixtures', screenshotsFolder: __dirname + '/screenshots', diff --git a/tests/cypress/integration/admin/common-feature-fields.test.js b/tests/cypress/integration/admin/common-feature-fields.test.js new file mode 100644 index 000000000..fec550d4a --- /dev/null +++ b/tests/cypress/integration/admin/common-feature-fields.test.js @@ -0,0 +1,92 @@ +describe('Common Feature Fields', () => { + beforeEach( () => { + cy.login(); + } ); + + const features = { + feature_classification: 'Classification', + feature_title_generation: 'Title Generation', + feature_excerpt_generation: 'Excerpt Generation', + feature_content_resizing: 'Content Resizing', + feature_text_to_speech_generation: 'Text to Speech', + feature_audio_transcripts_generation: 'Audio Transcripts Generation', + feature_image_generation: 'Image Generation', + feature_descriptive_text_generator: 'Descriptive Text Generator', + feature_image_tags_generator: 'Image Tags Generator', + feature_image_cropping: 'Image Cropping', + feature_image_to_text_generator: 'Image Text Extraction', + feature_pdf_to_text_generation: 'PDF Text Extraction', + }; + + const allowedRoles = [ + 'administrator', + 'editor', + 'author', + 'contributor', + 'subscriber', + ]; + + Object.keys( features ).forEach( ( feature ) => { + it( `"${ features[ feature ] }" feature common fields`, () => { + cy.visit( + `/wp-admin/tools.php?page=classifai&tab=language_processing&feature=${ feature }` + ); + + cy.get( '#status' ).should( + 'have.attr', + 'name', + `classifai_${ feature }[status]` + ); + cy.get( '#role_based_access' ).should( + 'have.attr', + 'name', + `classifai_${ feature }[role_based_access]` + ); + cy.get( '#user_based_access' ).should( + 'have.attr', + 'name', + `classifai_${ feature }[user_based_access]` + ); + cy.get( '#user_based_opt_out' ).should( + 'have.attr', + 'name', + `classifai_${ feature }[user_based_opt_out]` + ); + cy.get( '#provider' ).should( + 'have.attr', + 'name', + `classifai_${ feature }[provider]` + ); + cy.get( '#role_based_access' ).check(); + + for ( const role of allowedRoles ) { + if ( + 'feature_image_generation' === feature && + ( 'contributor' === role || 'subscriber' === role ) + ) { + continue; + } + + const roleField = cy.get( + `#classifai_${ feature }_roles_${ role }` + ); + roleField.should( 'be.visible' ); + roleField.should( 'have.value', role ); + roleField.should( + 'have.attr', + 'name', + `classifai_${ feature }[roles][${ role }]` + ); + } + + cy.get( '#role_based_access' ).uncheck(); + cy.get( '.allowed_roles_row' ).should( 'not.be.visible' ); + + cy.get( '#user_based_access' ).check(); + cy.get( '.allowed_users_row' ).should( 'be.visible' ); + + cy.get( '#user_based_access' ).uncheck(); + cy.get( '.allowed_users_row' ).should( 'not.be.visible' ); + } ); + } ); +} ); diff --git a/tests/cypress/integration/image-processing/image-generation-openai-dalle.test.js b/tests/cypress/integration/image-processing/image-generation-openai-dalle.test.js index be4a2efc4..0e0f8eed9 100644 --- a/tests/cypress/integration/image-processing/image-generation-openai-dalle.test.js +++ b/tests/cypress/integration/image-processing/image-generation-openai-dalle.test.js @@ -2,9 +2,9 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); - cy.get( '#enable_image_gen' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.optInAllFeatures(); } ); @@ -15,15 +15,17 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'Can save OpenAI "Image Processing" settings', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_image_gen' ).check(); - cy.get( '#openai_dalle_image_generation_roles_administrator' ).check(); - cy.get( '#number' ).select( '2' ); - cy.get( '#size' ).select( '512x512' ); + cy.get( '#status' ).check(); + cy.get( + '#classifai_feature_image_generation_roles_administrator' + ).check(); + cy.get( '#number_of_images' ).select( '2' ); + cy.get( '#image_size' ).select( '512x512' ); cy.get( '#submit' ).click(); } ); @@ -80,9 +82,9 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'Can enable/disable image generation feature', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); - cy.get( '#enable_image_gen' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -90,9 +92,9 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); - cy.get( '#enable_image_gen' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -101,11 +103,13 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'Can generate image directly in media library', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); - cy.get( '#enable_image_gen' ).check(); - cy.get( '#openai_dalle_image_generation_roles_administrator' ).check(); + cy.get( '#status' ).check(); + cy.get( + '#classifai_feature_image_generation_roles_administrator' + ).check(); cy.get( '#submit' ).click(); cy.visit( '/wp-admin/upload.php' ); @@ -128,27 +132,23 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'Can enable/disable image generation feature by role', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=image_processing&provider=openai_dalle' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_generation' ); - cy.get( '#enable_image_gen' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'image_generation', - [ 'administrator' ], - 'openai_dalle' - ); + cy.disableFeatureForRoles( 'feature_image_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyImageGenerationEnabled( false ); // Enable admin role. - cy.enableFeatureForRoles( - 'image_generation', - [ 'administrator' ], - 'openai_dalle' - ); + cy.enableFeatureForRoles( 'feature_image_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyImageGenerationEnabled( true ); @@ -156,21 +156,15 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'Can enable/disable image generation feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'image_generation', - [ 'administrator' ], - 'openai_dalle' - ); + cy.disableFeatureForRoles( 'feature_image_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyImageGenerationEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'image_generation', - [ 'admin' ], - 'openai_dalle' - ); + cy.enableFeatureForUsers( 'feature_image_generation', [ 'admin' ] ); // Verify that the feature is available. cy.verifyImageGenerationEnabled( true ); @@ -178,16 +172,16 @@ describe( 'Image Generation (OpenAI DALL路E) Tests', () => { it( 'User can opt-out image generation feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'image_generation', 'openai_dalle' ); + cy.enableFeatureOptOut( 'feature_image_generation' ); // opt-out - cy.optOutFeature( 'image_generation' ); + cy.optOutFeature( 'feature_image_generation' ); // Verify that the feature is not available. cy.verifyImageGenerationEnabled( false ); // opt-in - cy.optInFeature( 'image_generation' ); + cy.optInFeature( 'feature_image_generation' ); // Verify that the feature is available. cy.verifyImageGenerationEnabled( true ); diff --git a/tests/cypress/integration/image-processing/image-processing-microsoft-azure.test.js b/tests/cypress/integration/image-processing/image-processing-microsoft-azure.test.js index 85de16ff2..1750703ac 100644 --- a/tests/cypress/integration/image-processing/image-processing-microsoft-azure.test.js +++ b/tests/cypress/integration/image-processing/image-processing-microsoft-azure.test.js @@ -6,13 +6,27 @@ describe( 'Image processing Tests', () => { before( () => { cy.login(); - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - cy.get( '#computer_vision_enable_image_captions_alt' ).check(); - cy.get( '#computer_vision_enable_image_captions_description' ).check(); - cy.get( '#enable_image_tagging' ).check(); - cy.get( '#enable_smart_cropping' ).check(); - cy.get( '#enable_ocr' ).check(); - cy.get( '#submit' ).click(); + + const imageProcessingFeatures = [ + 'feature_descriptive_text_generator', + 'feature_image_tags_generator', + 'feature_image_cropping', + 'feature_image_to_text_generator', + 'feature_pdf_to_text_generation', + ]; + + imageProcessingFeatures.forEach( ( feature ) => { + cy.visit( + `/wp-admin/tools.php?page=classifai&tab=image_processing&feature=${ feature }` + ); + cy.get( '#status' ).check(); + cy.get( '#endpoint_url' ) + .clear() + .type( 'http://e2e-test-image-processing.test' ); + cy.get( '#api_key' ).clear().type( 'password' ); + cy.get( '#submit' ).click(); + } ); + cy.optInAllFeatures(); } ); @@ -20,24 +34,14 @@ describe( 'Image processing Tests', () => { cy.login(); } ); - it( 'Can save Azure AI Vision "Image Processing" settings', () => { - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - - cy.get( '#url' ) - .clear() - .type( 'http://e2e-test-image-processing.test' ); - cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#computer_vision_enable_image_captions_alt' ).check(); - cy.get( '#computer_vision_enable_image_captions_description' ).check(); - cy.get( '#enable_image_tagging' ).check(); - cy.get( '#enable_smart_cropping' ).check(); - cy.get( '#enable_ocr' ).check(); - cy.get( '#submit' ).click(); - - cy.get( '.notice' ).contains( 'Settings saved.' ); - } ); - it( 'Can see Azure AI Vision Image processing actions on edit media page and verify Generated data.', () => { + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_descriptive_text_generator' + ); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_alt' + ).check(); + cy.get( '#submit' ).click(); cy.visit( '/wp-admin/upload.php?mode=grid' ); // Ensure grid mode is enabled. cy.visit( '/wp-admin/media-new.php' ); cy.get( '#plupload-upload-ui' ).should( 'exist' ); @@ -56,20 +60,20 @@ describe( 'Image processing Tests', () => { } ); // Verify Metabox with Image processing actions. - cy.get( '.postbox-header h2, #attachment_meta_box h2' ) + cy.get( '.postbox-header h2, #classifai_image_processing h2' ) .first() .contains( 'ClassifAI Image Processing' ); cy.get( - '.misc-publishing-actions label[for=rescan-captions]' + '#classifai_image_processing label[for=rescan-captions]' ).contains( 'No descriptive text? Rescan image' ); - cy.get( '.misc-publishing-actions label[for=rescan-tags]' ).contains( + cy.get( '#classifai_image_processing label[for=rescan-tags]' ).contains( 'Rescan image for new tags' ); - cy.get( '.misc-publishing-actions label[for=rescan-ocr]' ).contains( + cy.get( '#classifai_image_processing label[for=rescan-ocr]' ).contains( 'Rescan for text' ); cy.get( - '.misc-publishing-actions label[for=rescan-smart-crop]' + '#classifai_image_processing label[for=rescan-smart-crop]' ).should( 'exist' ); // Verify generated Data. @@ -89,7 +93,7 @@ describe( 'Image processing Tests', () => { } ); } ); - it( 'Can see Azure AI Vision Image processing actions on media model', () => { + it( 'Can see Azure AI Vision Image processing actions on media modal', () => { const imageId = imageEditLink.split( 'post=' )[ 1 ]?.split( '&' )[ 0 ]; mediaModelLink = `wp-admin/upload.php?item=${ imageId }`; cy.visit( mediaModelLink ); @@ -109,26 +113,75 @@ describe( 'Image processing Tests', () => { }; // Disable features - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - cy.get( '#computer_vision_enable_image_captions_alt' ).uncheck(); - cy.get( '#computer_vision_enable_image_captions_caption' ).uncheck(); + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_descriptive_text_generator' + ); + cy.wait( 1000 ); cy.get( - '#computer_vision_enable_image_captions_description' + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_alt' ).uncheck(); - cy.get( '#enable_image_tagging' ).uncheck(); - cy.get( '#enable_smart_cropping' ).uncheck(); - cy.get( '#enable_ocr' ).uncheck(); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_caption' + ).uncheck(); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_description' + ).uncheck(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_tags_generator' + ); + cy.get( '#status' ).uncheck(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_cropping' + ); + cy.get( '#status' ).uncheck(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_to_text_generator' + ); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. cy.verifyAIVisionEnabled( false, options ); // Enable features. - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - cy.get( '#computer_vision_enable_image_captions_alt' ).check(); - cy.get( '#enable_image_tagging' ).check(); - cy.get( '#enable_smart_cropping' ).check(); - cy.get( '#enable_ocr' ).check(); + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_descriptive_text_generator' + ); + cy.wait( 1000 ); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_alt' + ).check(); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_caption' + ).check(); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_description' + ).check(); + cy.get( '#status' ).check(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_tags_generator' + ); + cy.get( '#status' ).check(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_cropping' + ); + cy.get( '#status' ).check(); + cy.get( '#submit' ).click(); + + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_image_to_text_generator' + ); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -142,59 +195,46 @@ describe( 'Image processing Tests', () => { }; // Enable features. - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - cy.get( '#computer_vision_enable_image_captions_alt' ).check(); - cy.get( '#enable_image_tagging' ).check(); - cy.get( '#enable_smart_cropping' ).check(); - cy.get( '#enable_ocr' ).check(); + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_descriptive_text_generator' + ); + cy.wait( 1000 ); + cy.get( + '#classifai_feature_descriptive_text_generator_descriptive_text_fields_alt' + ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Disable access to admin role. - cy.disableFeatureForRoles( - 'image_captions', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'image_tagging', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'smart_cropping', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'ocr', - [ 'administrator' ], - 'computer_vision' - ); + cy.disableFeatureForRoles( 'feature_descriptive_text_generator', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_tags_generator', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_cropping', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_to_text_generator', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyAIVisionEnabled( false, options ); // Enable access to admin role. - cy.enableFeatureForRoles( - 'image_captions', - [ 'administrator' ], - 'computer_vision' - ); - cy.enableFeatureForRoles( - 'image_tagging', - [ 'administrator' ], - 'computer_vision' - ); - cy.enableFeatureForRoles( - 'smart_cropping', - [ 'administrator' ], - 'computer_vision' - ); - cy.enableFeatureForRoles( - 'ocr', - [ 'administrator' ], - 'computer_vision' - ); + cy.enableFeatureForRoles( 'feature_descriptive_text_generator', [ + 'administrator', + ] ); + cy.enableFeatureForRoles( 'feature_image_tags_generator', [ + 'administrator', + ] ); + cy.enableFeatureForRoles( 'feature_image_cropping', [ + 'administrator', + ] ); + cy.enableFeatureForRoles( 'feature_image_to_text_generator', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyAIVisionEnabled( true, options ); @@ -207,46 +247,30 @@ describe( 'Image processing Tests', () => { }; // Disable access to admin role. - cy.disableFeatureForRoles( - 'image_captions', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'image_tagging', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'smart_cropping', - [ 'administrator' ], - 'computer_vision' - ); - cy.disableFeatureForRoles( - 'ocr', - [ 'administrator' ], - 'computer_vision' - ); + cy.disableFeatureForRoles( 'feature_descriptive_text_generator', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_tags_generator', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_cropping', [ + 'administrator', + ] ); + cy.disableFeatureForRoles( 'feature_image_to_text_generator', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyAIVisionEnabled( false, options ); - cy.enableFeatureForUsers( - 'image_captions', - [ 'admin' ], - 'computer_vision' - ); - cy.enableFeatureForUsers( - 'image_tagging', - [ 'admin' ], - 'computer_vision' - ); - cy.enableFeatureForUsers( - 'smart_cropping', - [ 'admin' ], - 'computer_vision' - ); - cy.enableFeatureForUsers( 'ocr', [ 'admin' ], 'computer_vision' ); + cy.enableFeatureForUsers( 'feature_descriptive_text_generator', [ + 'admin', + ] ); + cy.enableFeatureForUsers( 'feature_image_tags_generator', [ 'admin' ] ); + cy.enableFeatureForUsers( 'feature_image_cropping', [ 'admin' ] ); + cy.enableFeatureForUsers( 'feature_image_to_text_generator', [ + 'admin', + ] ); // Verify that the feature is available. cy.verifyAIVisionEnabled( true, options ); @@ -259,25 +283,25 @@ describe( 'Image processing Tests', () => { }; // Enable user based opt-out. - cy.enableFeatureOptOut( 'image_captions', 'computer_vision' ); - cy.enableFeatureOptOut( 'image_tagging', 'computer_vision' ); - cy.enableFeatureOptOut( 'smart_cropping', 'computer_vision' ); - cy.enableFeatureOptOut( 'ocr', 'computer_vision' ); + cy.enableFeatureOptOut( 'feature_descriptive_text_generator' ); + cy.enableFeatureOptOut( 'feature_image_tags_generator' ); + cy.enableFeatureOptOut( 'feature_image_cropping' ); + cy.enableFeatureOptOut( 'feature_image_to_text_generator' ); // opt-out - cy.optOutFeature( 'image_captions' ); - cy.optOutFeature( 'image_tagging' ); - cy.optOutFeature( 'smart_cropping' ); - cy.optOutFeature( 'ocr' ); + cy.optOutFeature( 'feature_descriptive_text_generator' ); + cy.optOutFeature( 'feature_image_tags_generator' ); + cy.optOutFeature( 'feature_image_cropping' ); + cy.optOutFeature( 'feature_image_to_text_generator' ); // Verify that the feature is not available. cy.verifyAIVisionEnabled( false, options ); // opt-in - cy.optInFeature( 'image_captions' ); - cy.optInFeature( 'image_tagging' ); - cy.optInFeature( 'smart_cropping' ); - cy.optInFeature( 'ocr' ); + cy.optInFeature( 'feature_descriptive_text_generator' ); + cy.optInFeature( 'feature_image_tags_generator' ); + cy.optInFeature( 'feature_image_cropping' ); + cy.optInFeature( 'feature_image_to_text_generator' ); // Verify that the feature is available. cy.verifyAIVisionEnabled( true, options ); diff --git a/tests/cypress/integration/image-processing/pdf-read.test.js b/tests/cypress/integration/image-processing/pdf-read.test.js index 29bb2f10a..59c79437a 100644 --- a/tests/cypress/integration/image-processing/pdf-read.test.js +++ b/tests/cypress/integration/image-processing/pdf-read.test.js @@ -3,8 +3,10 @@ import { getPDFData } from '../../plugins/functions'; describe( 'PDF read Tests', () => { before( () => { cy.login(); - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); - cy.get( '#enable_read_pdf' ).check(); + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_pdf_to_text_generation' + ); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.optInAllFeatures(); } ); @@ -15,13 +17,15 @@ describe( 'PDF read Tests', () => { let pdfEditLink = ''; it( 'Can save "PDF scanning" settings', () => { - cy.visit( '/wp-admin/tools.php?page=classifai&tab=image_processing' ); + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_pdf_to_text_generation' + ); - cy.get( '#url' ) + cy.get( '#endpoint_url' ) .clear() .type( 'http://e2e-test-image-processing.test' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_read_pdf' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -59,9 +63,9 @@ describe( 'PDF read Tests', () => { it( 'Can enable/disable PDF scanning feature', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=computer_vision' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_pdf_to_text_generation' ); - cy.get( '#enable_read_pdf' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -72,9 +76,9 @@ describe( 'PDF read Tests', () => { // Enable admin role. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=computer_vision' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_pdf_to_text_generation' ); - cy.get( '#enable_read_pdf' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -87,17 +91,15 @@ describe( 'PDF read Tests', () => { it( 'Can enable/disable PDF scanning feature by role', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=computer_vision' + '/wp-admin/tools.php?page=classifai&tab=image_processing&feature=feature_pdf_to_text_generation' ); - cy.get( '#enable_read_pdf' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'read_pdf', - [ 'administrator' ], - 'computer_vision' - ); + cy.disableFeatureForRoles( 'feature_pdf_to_text_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.visit( pdfEditLink ); @@ -106,11 +108,9 @@ describe( 'PDF read Tests', () => { ); // Enable admin role. - cy.enableFeatureForRoles( - 'read_pdf', - [ 'administrator' ], - 'computer_vision' - ); + cy.enableFeatureForRoles( 'feature_pdf_to_text_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.visit( pdfEditLink ); @@ -121,11 +121,9 @@ describe( 'PDF read Tests', () => { it( 'Can enable/disable PDF scanning feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'read_pdf', - [ 'administrator' ], - 'computer_vision' - ); + cy.disableFeatureForRoles( 'feature_pdf_to_text_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.visit( pdfEditLink ); @@ -134,7 +132,9 @@ describe( 'PDF read Tests', () => { ); // Enable feature for admin user. - cy.enableFeatureForUsers( 'read_pdf', [ 'admin' ], 'computer_vision' ); + cy.enableFeatureForUsers( 'feature_pdf_to_text_generation', [ + 'admin', + ] ); // Verify that the feature is available. cy.visit( pdfEditLink ); @@ -145,10 +145,10 @@ describe( 'PDF read Tests', () => { it( 'User can opt-out PDF scanning feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'read_pdf', 'computer_vision' ); + cy.enableFeatureOptOut( 'feature_pdf_to_text_generation' ); // opt-out - cy.optOutFeature( 'read_pdf' ); + cy.optOutFeature( 'feature_pdf_to_text_generation' ); // Verify that the feature is not available. cy.visit( pdfEditLink ); @@ -157,7 +157,7 @@ describe( 'PDF read Tests', () => { ); // opt-in - cy.optInFeature( 'read_pdf' ); + cy.optInFeature( 'feature_pdf_to_text_generation' ); // Verify that the feature is available. cy.visit( pdfEditLink ); diff --git a/tests/cypress/integration/language-processing/classify-content-ibm-watson.test.js b/tests/cypress/integration/language-processing/classify-content-ibm-watson.test.js index 4bd8e9182..8094e05bd 100644 --- a/tests/cypress/integration/language-processing/classify-content-ibm-watson.test.js +++ b/tests/cypress/integration/language-processing/classify-content-ibm-watson.test.js @@ -2,13 +2,26 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#classifai-settings-post' ).check(); - cy.get( '#classifai-settings-publish' ).check(); - cy.get( '#classifai-settings-category' ).check(); - cy.get( '#watson_nlu_classification_method_recommended_terms' ).check(); - cy.get( '#classifai-settings-enable_content_classification' ).check(); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( '#endpoint_url' ) + .clear() + .type( 'http://e2e-test-nlu-server.test/' ); + cy.get( '#password' ).clear().type( 'password' ); + cy.get( '#classifai-waston-cred-toggle' ).click(); + cy.get( '#classifai_feature_classification_post_types_post' ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_publish' + ).check(); + cy.get( '#status' ).check(); + cy.get( '#submit' ).click(); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_method_recommended_terms' + ).check(); + cy.wait( 1000 ); + cy.get( '#category' ).check(); cy.get( '#submit' ).click(); cy.optInAllFeatures(); cy.disableClassicEditor(); @@ -21,34 +34,31 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () it( 'Can save IBM Watson "Language Processing" settings', () => { // Disable content classification by openai. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); - cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' - ); + cy.get( '#status' ).check(); + cy.get( '#classifai_feature_classification_post_types_post' ).check(); + cy.get( '#classifai_feature_classification_post_types_page' ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_draft' + ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_pending' + ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_private' + ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_publish' + ).check(); - cy.get( '#classifai-settings-watson_url' ) - .clear() - .type( 'http://e2e-test-nlu-server.test/' ); - cy.get( '#classifai-settings-watson_password' ) - .clear() - .type( 'password' ); - - cy.get( '#classifai-settings-automatic_classification' ).check(); - cy.get( '#classifai-settings-post' ).check(); - cy.get( '#classifai-settings-page' ).check(); - cy.get( '#classifai-settings-draft' ).check(); - cy.get( '#classifai-settings-pending' ).check(); - cy.get( '#classifai-settings-private' ).check(); - cy.get( '#classifai-settings-publish' ).check(); - - cy.get( '#classifai-settings-category' ).check(); - cy.get( '#classifai-settings-keyword' ).check(); - cy.get( '#classifai-settings-entity' ).check(); - cy.get( '#classifai-settings-concept' ).check(); + cy.get( '#category' ).check(); + cy.get( '#keyword' ).check(); + cy.get( '#entity' ).check(); + cy.get( '#concept' ).check(); cy.get( '#submit' ).click(); } ); @@ -94,7 +104,10 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () '/wp-admin/tools.php?page=classifai&tab=language_processing' ); - cy.get( '#classifai-settings-manual_review' ).check(); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_mode_manual_review' + ).check(); cy.get( '#submit' ).click(); // Create Test Post @@ -177,10 +190,13 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.deactivatePlugin( 'classic-editor' ); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#classifai-settings-automatic_classification' ).check(); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_mode_automatic_classification' + ).check(); cy.get( '#submit' ).click(); // Create Test Post @@ -251,21 +267,13 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () // Update Threshold to 75. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#classifai-settings-category_threshold' ) - .clear() - .type( threshold ); - cy.get( '#classifai-settings-keyword_threshold' ) - .clear() - .type( threshold ); - cy.get( '#classifai-settings-entity_threshold' ) - .clear() - .type( threshold ); - cy.get( '#classifai-settings-concept_threshold' ) - .clear() - .type( threshold ); + cy.get( '#category_threshold' ).clear().type( threshold ); + cy.get( '#keyword_threshold' ).clear().type( threshold ); + cy.get( '#entity_threshold' ).clear().type( threshold ); + cy.get( '#concept_threshold' ).clear().type( threshold ); cy.get( '#submit' ).click(); // Create Test Post @@ -303,22 +311,17 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () const threshold1 = 75; // Update classification method to "Add recommended terms" and threshold value. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#watson_nlu_classification_method_recommended_terms' ).check(); - cy.get( '#classifai-settings-category_threshold' ) - .clear() - .type( threshold1 ); - cy.get( '#classifai-settings-keyword_threshold' ) - .clear() - .type( threshold1 ); - cy.get( '#classifai-settings-entity_threshold' ) - .clear() - .type( threshold1 ); - cy.get( '#classifai-settings-concept_threshold' ) - .clear() - .type( threshold1 ); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_method_recommended_terms' + ).check(); + cy.get( '#category_threshold' ).clear().type( threshold1 ); + cy.get( '#keyword_threshold' ).clear().type( threshold1 ); + cy.get( '#entity_threshold' ).clear().type( threshold1 ); + cy.get( '#concept_threshold' ).clear().type( threshold1 ); cy.get( '#submit' ).click(); // Create Test Post @@ -349,22 +352,17 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () const threshold2 = 70; // Update classification method to "Only classify based on existing terms" and threshold value. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#watson_nlu_classification_method_existing_terms' ).check(); - cy.get( '#classifai-settings-category_threshold' ) - .clear() - .type( threshold2 ); - cy.get( '#classifai-settings-keyword_threshold' ) - .clear() - .type( threshold2 ); - cy.get( '#classifai-settings-entity_threshold' ) - .clear() - .type( threshold2 ); - cy.get( '#classifai-settings-concept_threshold' ) - .clear() - .type( threshold2 ); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_method_existing_terms' + ).check(); + cy.get( '#category_threshold' ).clear().type( threshold2 ); + cy.get( '#keyword_threshold' ).clear().type( threshold2 ); + cy.get( '#entity_threshold' ).clear().type( threshold2 ); + cy.get( '#concept_threshold' ).clear().type( threshold2 ); cy.get( '#submit' ).click(); // Create Test Post @@ -393,23 +391,32 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () // Update classification method back to "Add recommended terms". cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#watson_nlu_classification_method_recommended_terms' ).check(); + cy.get( + '#classifai_feature_classification_classification_method_recommended_terms' + ).check(); cy.get( '#submit' ).click(); } ); it( 'Can create post and tags get created by ClassifAI', () => { const threshold = 70; cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#watson_nlu_classification_method_recommended_terms' ).check(); + cy.get( '#provider' ).select( 'ibm_watson_nlu' ); + cy.get( + '#classifai_feature_classification_classification_method_recommended_terms' + ).check(); cy.get( '#classifai-settings-category_taxonomy' ).select( 'post_tag' ); cy.get( '#classifai-settings-keyword_taxonomy' ).select( 'post_tag' ); cy.get( '#classifai-settings-entity_taxonomy' ).select( 'post_tag' ); cy.get( '#classifai-settings-concept_taxonomy' ).select( 'post_tag' ); + cy.get( '#category_threshold' ).clear().type( threshold ); + cy.get( '#keyword_threshold' ).clear().type( threshold ); + cy.get( '#entity_threshold' ).clear().type( threshold ); + cy.get( '#concept_threshold' ).clear().type( threshold ); cy.get( '#submit' ).click(); // Create Test Post @@ -436,9 +443,9 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () it( 'Can enable/disable Natural Language Understanding features.', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#classifai-settings-enable_content_classification' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -446,9 +453,9 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#classifai-settings-enable_content_classification' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -458,13 +465,11 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () it( 'Can limit Natural Language Understanding features by roles', () => { // Disable access to admin role. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); + cy.get( '#role_based_access' ).check(); cy.get( - '#classifai-settings-content_classification_role_based_access' - ).check(); - cy.get( - '#watson_nlu_content_classification_roles_administrator' + '#classifai_feature_classification_roles_administrator' ).uncheck(); cy.get( '#submit' ).click(); @@ -477,11 +482,9 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.visit( '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' ); + cy.get( '#role_based_access' ).check(); cy.get( - '#classifai-settings-content_classification_role_based_access' - ).check(); - cy.get( - '#watson_nlu_content_classification_roles_administrator' + '#classifai_feature_classification_roles_administrator' ).check(); cy.get( '#submit' ).click(); @@ -496,12 +499,8 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.visit( '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' ); - cy.get( - '#classifai-settings-content_classification_role_based_access' - ).uncheck(); - cy.get( - '#classifai-settings-content_classification_user_based_access' - ).uncheck(); + cy.get( '#role_based_access' ).uncheck(); + cy.get( '#user_based_access' ).uncheck(); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -512,27 +511,23 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.visit( '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' ); - cy.get( - '#classifai-settings-content_classification_role_based_access' - ).uncheck(); - cy.get( - '#classifai-settings-content_classification_user_based_access' - ).check(); + cy.get( '#role_based_access' ).uncheck(); + cy.get( '#user_based_access' ).check(); cy.get( 'body' ).then( ( $body ) => { if ( $body.find( - '#content_classification_users-container .components-form-token-field__remove-token' + '.allowed_users_row .components-form-token-field__remove-token' ).length > 0 ) { cy.get( - '#content_classification_users-container .components-form-token-field__remove-token' + '.allowed_users_row .components-form-token-field__remove-token' ).click( { multiple: true, } ); } } ); cy.get( - '#content_classification_users-container input.components-form-token-field__input' + '.allowed_users_row input.components-form-token-field__input' ).type( 'admin' ); cy.wait( 1000 ); cy.get( @@ -548,12 +543,8 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.visit( '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' ); - cy.get( - '#classifai-settings-content_classification_role_based_access' - ).check(); - cy.get( - '#classifai-settings-content_classification_user_based_access' - ).uncheck(); + cy.get( '#role_based_access' ).check(); + cy.get( '#user_based_access' ).uncheck(); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -564,27 +555,21 @@ describe( '[Language processing] Classify content (IBM Watson - NLU) Tests', () cy.visit( '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' ); - cy.get( - '#classifai-settings-content_classification_role_based_access' - ).check(); - cy.get( - '#classifai-settings-content_classification_user_based_access' - ).check(); - cy.get( - '#classifai-settings-content_classification_user_based_opt_out' - ).check(); + cy.get( '#role_based_access' ).check(); + cy.get( '#user_based_access' ).check(); + cy.get( '#user_based_opt_out' ).check(); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); // opt-out - cy.optOutFeature( 'content_classification' ); + cy.optOutFeature( 'feature_classification' ); // Verify that the feature is not available. cy.verifyClassifyContentEnabled( false ); // opt-in - cy.optInFeature( 'content_classification' ); + cy.optInFeature( 'feature_classification' ); // Verify that the feature is available. cy.verifyClassifyContentEnabled( true ); diff --git a/tests/cypress/integration/language-processing/classify-content-openapi-embeddings.test.js b/tests/cypress/integration/language-processing/classify-content-openapi-embeddings.test.js index 4434e10fc..c0ef814e7 100644 --- a/tests/cypress/integration/language-processing/classify-content-openapi-embeddings.test.js +++ b/tests/cypress/integration/language-processing/classify-content-openapi-embeddings.test.js @@ -2,9 +2,10 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).check(); + cy.get( '#status' ).check(); + cy.get( '#provider' ).select( 'openai_embeddings' ); cy.get( '#submit' ).click(); cy.optInAllFeatures(); cy.disableClassicEditor(); @@ -16,28 +17,50 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { it( 'Can save OpenAI Embeddings "Language Processing" settings', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_classification' ).check(); - cy.get( '#openai_embeddings_post_types_post' ).check(); - cy.get( '#openai_embeddings_post_statuses_publish' ).check(); - cy.get( '#openai_embeddings_taxonomies_category' ).check(); - cy.get( '#openai_embeddings_taxonomies_category_threshold' ).type( 80 ); // "Test" requires 80% confidence. At 81%, it does not apply. - cy.get( '#number' ).clear().type( 1 ); + cy.get( '#status' ).check(); + cy.get( '#classifai_feature_classification_post_types_post' ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_publish' + ).check(); + cy.get( + '#classifai_feature_classification_openai_embeddings_taxonomies_category' + ).check(); + cy.get( + '#classifai_feature_classification_openai_embeddings_taxonomies_category_threshold' + ) + .clear() + .type( 100 ); // "Test" requires 80% confidence. At 81%, it does not apply. + cy.get( '#number_of_terms' ).clear().type( 1 ); cy.get( '#submit' ).click(); } ); + it( 'Can see the preview on the settings page', () => { + cy.visit( + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' + ); + + cy.get( '#submit' ).click(); + + // Click the Preview button. + const closePanelSelector = '#get-classifier-preview-data-btn'; + cy.get( closePanelSelector ).click(); + + // Check the term is received and visible. + cy.get( '.tax-row--Category' ).should( 'exist' ); + } ); + it( 'Can create category and post and category will get auto-assigned', () => { // Remove custom taxonomies so those don't interfere with the test. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' + '/wp-admin/tools.php?page=classifai&tab=language_processing' ); - cy.get( '#classifai-settings-category' ).uncheck(); - cy.get( '#classifai-settings-keyword' ).uncheck(); - cy.get( '#classifai-settings-entity' ).uncheck(); - cy.get( '#classifai-settings-concept' ).uncheck(); + cy.get( + '#classifai_feature_classification_openai_embeddings_taxonomies_category' + ).uncheck(); cy.get( '#submit' ).click(); // Create test term. @@ -80,31 +103,17 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { ) .should( 'be.checked' ); cy.wrap( $panel ) - .find( - '.editor-post-taxonomies__hierarchical-terms-list .editor-post-taxonomies__hierarchical-terms-choice:first label' - ) + .find( '.editor-post-taxonomies__hierarchical-terms-list' ) + .children() .contains( 'Test' ); } ); } ); - it( 'Can see the preview on the settings page', () => { - cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' - ); - - // Click the Preview button. - const closePanelSelector = '#get-classifier-preview-data-btn'; - cy.get( closePanelSelector ).click(); - - // Check the term is received and visible. - cy.get( '.tax-row--Category' ).should( 'exist' ); - } ); - it( 'Can create category and post and category will not get auto-assigned if feature turned off', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Create test term. @@ -158,14 +167,18 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { cy.enableClassicEditor(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).check(); - cy.get( '#openai_embeddings_post_types_post' ).check(); - cy.get( '#openai_embeddings_post_statuses_publish' ).check(); - cy.get( '#openai_embeddings_taxonomies_category' ).check(); - cy.get( '#number' ).clear().type( 1 ); + cy.get( '#status' ).check(); + cy.get( '#classifai_feature_classification_post_types_post' ).check(); + cy.get( + '#classifai_feature_classification_post_statuses_publish' + ).check(); + cy.get( + '#classifai_feature_classification_openai_embeddings_taxonomies_category' + ).check(); + cy.get( '#number_of_terms' ).clear().type( 1 ); cy.get( '#submit' ).click(); cy.classicCreatePost( { @@ -183,9 +196,9 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { it( 'Can enable/disable content classification feature ', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -193,9 +206,9 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_embeddings' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_classification' ); - cy.get( '#enable_classification' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -205,30 +218,23 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { it( 'Can enable/disable content classification feature by role', () => { // Remove custom taxonomies so those don't interfere with the test. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=watson_nlu' + '/wp-admin/tools.php?page=classifai&tab=language_processing' ); - cy.get( '#classifai-settings-category' ).uncheck(); - cy.get( '#classifai-settings-keyword' ).uncheck(); - cy.get( '#classifai-settings-entity' ).uncheck(); - cy.get( '#classifai-settings-concept' ).uncheck(); + cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'classification', - [ 'administrator' ], - 'openai_embeddings' - ); + cy.disableFeatureForRoles( 'feature_classification', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyClassifyContentEnabled( false ); // Enable admin role. - cy.enableFeatureForRoles( - 'classification', - [ 'administrator' ], - 'openai_embeddings' - ); + cy.enableFeatureForRoles( 'feature_classification', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyClassifyContentEnabled( true ); @@ -236,21 +242,15 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { it( 'Can enable/disable content classification feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'classification', - [ 'administrator' ], - 'openai_embeddings' - ); + cy.disableFeatureForRoles( 'feature_classification', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyClassifyContentEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'classification', - [ 'admin' ], - 'openai_embeddings' - ); + cy.enableFeatureForUsers( 'feature_classification', [ 'admin' ] ); // Verify that the feature is available. cy.verifyClassifyContentEnabled( true ); @@ -258,16 +258,16 @@ describe( '[Language processing] Classify Content (OpenAI) Tests', () => { it( 'User can opt-out content classification feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'classification', 'openai_embeddings' ); + cy.enableFeatureOptOut( 'feature_classification', 'openai_embeddings' ); // opt-out - cy.optOutFeature( 'classification' ); + cy.optOutFeature( 'feature_classification' ); // Verify that the feature is not available. cy.verifyClassifyContentEnabled( false ); // opt-in - cy.optInFeature( 'classification' ); + cy.optInFeature( 'feature_classification' ); // Verify that the feature is available. cy.verifyClassifyContentEnabled( true ); diff --git a/tests/cypress/integration/language-processing/excerpt-generation-openapi-chatgpt.test.js b/tests/cypress/integration/language-processing/excerpt-generation-openapi-chatgpt.test.js index ce1aa2d88..e64d5a2c7 100644 --- a/tests/cypress/integration/language-processing/excerpt-generation-openapi-chatgpt.test.js +++ b/tests/cypress/integration/language-processing/excerpt-generation-openapi-chatgpt.test.js @@ -4,9 +4,9 @@ describe( '[Language processing] Excerpt Generation Tests', () => { before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); - cy.get( '#enable_excerpt' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.optInAllFeatures(); cy.disableClassicEditor(); @@ -18,15 +18,15 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'Can save OpenAI ChatGPT "Language Processing" settings', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_excerpt' ).check(); - cy.get( '#excerpt_generation_role_based_access' ).check(); + cy.get( '#status' ).check(); + cy.get( '#role_based_access' ).check(); cy.get( - '#openai_chatgpt_excerpt_generation_roles_administrator' + '#classifai_feature_excerpt_generation_roles_administrator' ).check(); cy.get( '#length' ).clear().type( 35 ); cy.get( '#submit' ).click(); @@ -82,9 +82,9 @@ describe( '[Language processing] Excerpt Generation Tests', () => { cy.enableClassicEditor(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); - cy.get( '#enable_excerpt' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); const data = getChatGPTData(); @@ -112,12 +112,12 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'Can set multiple custom excerpt generation prompts, select one as the default and delete one.', () => { cy.disableClassicEditor(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); // Add three custom prompts. cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][0][default]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][0][default]"]' ) .parents( 'td:first' ) .find( 'button.js-classifai-add-prompt-fieldset' ) @@ -125,7 +125,7 @@ describe( '[Language processing] Excerpt Generation Tests', () => { .click() .click(); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][0][default]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][0][default]"]' ) .parents( 'td' ) .find( '.classifai-field-type-prompt-setting' ) @@ -133,40 +133,40 @@ describe( '[Language processing] Excerpt Generation Tests', () => { // Set the data for each prompt. cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][1][title]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][1][title]"]' ) .clear() .type( 'First custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][1][prompt]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][1][prompt]"]' ) .clear() .type( 'This is our first custom excerpt prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][2][title]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][2][title]"]' ) .clear() .type( 'Second custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][2][prompt]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][2][prompt]"]' ) .clear() .type( 'This prompt should be deleted' ); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][3][title]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][3][title]"]' ) .clear() .type( 'Third custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][3][prompt]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][3][prompt]"]' ) .clear() .type( 'This is a custom excerpt prompt' ); // Set the third prompt as our default. cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][3][default]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][3][default]"]' ) .parent() .find( 'a.action__set_default' ) @@ -174,7 +174,7 @@ describe( '[Language processing] Excerpt Generation Tests', () => { // Delete the second prompt. cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][2][default]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][2][default]"]' ) .parent() .find( 'a.action__remove_prompt' ) @@ -183,7 +183,7 @@ describe( '[Language processing] Excerpt Generation Tests', () => { .find( '.button-primary' ) .click(); cy.get( - '[name="classifai_openai_chatgpt[generate_excerpt_prompt][0][default]"]' + '[name="classifai_feature_excerpt_generation[generate_excerpt_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -236,9 +236,9 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'Can enable/disable excerpt generation feature', () => { // Disable features. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); - cy.get( '#enable_excerpt' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -246,9 +246,9 @@ describe( '[Language processing] Excerpt Generation Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); - cy.get( '#enable_excerpt' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -257,27 +257,23 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'Can enable/disable excerpt generation feature by role', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_excerpt_generation' ); - cy.get( '#enable_excerpt' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'excerpt_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_excerpt_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyExcerptGenerationEnabled( false ); // enable admin role. - cy.enableFeatureForRoles( - 'excerpt_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.enableFeatureForRoles( 'feature_excerpt_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyExcerptGenerationEnabled( true ); @@ -285,21 +281,17 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'Can enable/disable excerpt generation feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'excerpt_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_excerpt_generation', [ + 'administrator', + ] ); + + cy.enableFeatureForUsers( 'feature_excerpt_generation', [] ); // Verify that the feature is not available. cy.verifyExcerptGenerationEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'excerpt_generation', - [ 'admin' ], - 'openai_chatgpt' - ); + cy.enableFeatureForUsers( 'feature_excerpt_generation', [ 'admin' ] ); // Verify that the feature is available. cy.verifyExcerptGenerationEnabled( true ); @@ -307,16 +299,19 @@ describe( '[Language processing] Excerpt Generation Tests', () => { it( 'User can opt-out excerpt generation feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'excerpt_generation', 'openai_chatgpt' ); + cy.enableFeatureOptOut( + 'feature_excerpt_generation', + 'openai_chatgpt' + ); // opt-out - cy.optOutFeature( 'excerpt_generation' ); + cy.optOutFeature( 'feature_excerpt_generation' ); // Verify that the feature is not available. cy.verifyExcerptGenerationEnabled( false ); // opt-in - cy.optInFeature( 'excerpt_generation' ); + cy.optInFeature( 'feature_excerpt_generation' ); // Verify that the feature is available. cy.verifyExcerptGenerationEnabled( true ); diff --git a/tests/cypress/integration/language-processing/resize_content-openapi-chatgpt.test.js b/tests/cypress/integration/language-processing/resize_content-openapi-chatgpt.test.js index e79250670..9d4fbb0c9 100644 --- a/tests/cypress/integration/language-processing/resize_content-openapi-chatgpt.test.js +++ b/tests/cypress/integration/language-processing/resize_content-openapi-chatgpt.test.js @@ -2,9 +2,10 @@ describe( '[Language processing] Speech to Text Tests', () => { before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_content_resizing' ); - cy.get( '#enable_resize_content' ).check(); + cy.get( '#status' ).check(); + cy.get( '#api_key' ).type( 'abc123' ); cy.get( '#submit' ).click(); cy.optInAllFeatures(); cy.disableClassicEditor(); @@ -16,11 +17,13 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Resize content feature can grow and shrink content', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_content_resizing' ); - cy.get( '#enable_resize_content' ).check(); - cy.get( '#openai_chatgpt_resize_content_roles_administrator' ).check(); + cy.get( '#status' ).check(); + cy.get( + '#classifai_feature_content_resizing_roles_administrator' + ).check(); cy.get( '#submit' ).click(); cy.createPost( { @@ -73,12 +76,12 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can set multiple custom resize generation prompts, select one as the default and delete one.', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_content_resizing' ); // Add three custom shrink prompts. cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( 'button.js-classifai-add-prompt-fieldset' ) @@ -86,7 +89,7 @@ describe( '[Language processing] Speech to Text Tests', () => { .click() .click(); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -94,7 +97,7 @@ describe( '[Language processing] Speech to Text Tests', () => { // Add three custom grow prompts. cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( 'button.js-classifai-add-prompt-fieldset:first' ) @@ -102,7 +105,7 @@ describe( '[Language processing] Speech to Text Tests', () => { .click() .click(); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -110,77 +113,77 @@ describe( '[Language processing] Speech to Text Tests', () => { // Set the data for each prompt. cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][1][title]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][1][title]"]' ) .clear() .type( 'First custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][1][prompt]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][1][prompt]"]' ) .clear() .type( 'This is our first custom shrink prompt' ); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][2][title]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][2][title]"]' ) .clear() .type( 'Second custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][2][prompt]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][2][prompt]"]' ) .clear() .type( 'This prompt should be deleted' ); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][3][title]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][3][title]"]' ) .clear() .type( 'Third custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][3][prompt]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][3][prompt]"]' ) .clear() .type( 'This is a custom shrink prompt' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][1][title]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][1][title]"]' ) .clear() .type( 'First custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][1][prompt]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][1][prompt]"]' ) .clear() .type( 'This is our first custom grow prompt' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][2][title]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][2][title]"]' ) .clear() .type( 'Second custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][2][prompt]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][2][prompt]"]' ) .clear() .type( 'This prompt should be deleted' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][3][title]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][3][title]"]' ) .clear() .type( 'Third custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][3][prompt]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][3][prompt]"]' ) .clear() .type( 'This is a custom grow prompt' ); // Set the third prompt as our default. cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][3][default]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][3][default]"]' ) .parent() .find( 'a.action__set_default' ) .click( { force: true } ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][3][default]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][3][default]"]' ) .parent() .find( 'a.action__set_default' ) @@ -188,7 +191,7 @@ describe( '[Language processing] Speech to Text Tests', () => { // Delete the second prompt. cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][2][default]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][2][default]"]' ) .parent() .find( 'a.action__remove_prompt' ) @@ -197,22 +200,23 @@ describe( '[Language processing] Speech to Text Tests', () => { .find( '.button-primary' ) .click(); cy.get( - '[name="classifai_openai_chatgpt[shrink_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[condense_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) .should( 'have.length', 3 ); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][2][default]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][2][default]"]' ) .parent() .find( 'a.action__remove_prompt' ) .click( { force: true } ); cy.get( 'div[aria-describedby="js-classifai--delete-prompt-modal"]' ) + .first() .find( '.button-primary' ) .click(); cy.get( - '[name="classifai_openai_chatgpt[grow_content_prompt][0][default]"]' + '[name="classifai_feature_content_resizing[expand_text_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -271,9 +275,9 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can enable/disable resize content feature', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_content_resizing' ); - cy.get( '#enable_resize_content' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -281,9 +285,9 @@ describe( '[Language processing] Speech to Text Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_content_resizing' ); - cy.get( '#enable_resize_content' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -292,21 +296,17 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can enable/disable resize content feature by role', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'resize_content', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_content_resizing', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyResizeContentEnabled( false ); // Enable admin role. - cy.enableFeatureForRoles( - 'resize_content', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.enableFeatureForRoles( 'feature_content_resizing', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyResizeContentEnabled( true ); @@ -314,21 +314,15 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can enable/disable resize content feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'resize_content', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_content_resizing', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyResizeContentEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'resize_content', - [ 'admin' ], - 'openai_chatgpt' - ); + cy.enableFeatureForUsers( 'feature_content_resizing', [ 'admin' ] ); // Verify that the feature is available. cy.verifyResizeContentEnabled( true ); @@ -336,16 +330,16 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'User can opt-out resize content feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'resize_content', 'openai_chatgpt' ); + cy.enableFeatureOptOut( 'feature_content_resizing' ); // opt-out - cy.optOutFeature( 'resize_content' ); + cy.optOutFeature( 'feature_content_resizing' ); // Verify that the feature is not available. cy.verifyResizeContentEnabled( false ); // opt-in - cy.optInFeature( 'resize_content' ); + cy.optInFeature( 'feature_content_resizing' ); // Verify that the feature is available. cy.verifyResizeContentEnabled( true ); diff --git a/tests/cypress/integration/language-processing/speech-to-text-openapi-whisper.test.js b/tests/cypress/integration/language-processing/speech-to-text-openapi-whisper.test.js index fea371a00..9e04582d5 100644 --- a/tests/cypress/integration/language-processing/speech-to-text-openapi-whisper.test.js +++ b/tests/cypress/integration/language-processing/speech-to-text-openapi-whisper.test.js @@ -4,9 +4,9 @@ describe( '[Language processing] Speech to Text Tests', () => { before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_whisper' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_audio_transcripts_generation' ); - cy.get( '#enable_transcripts' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.optInAllFeatures(); cy.disableClassicEditor(); @@ -18,13 +18,15 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can save OpenAI Whisper "Language Processing" settings', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_whisper' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_audio_transcripts_generation' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_transcripts' ).check(); - cy.get( '#openai_whisper_speech_to_text_roles_administrator' ).check(); + cy.get( '#status' ).check(); + cy.get( + '#classifai_feature_audio_transcripts_generation_roles_administrator' + ).check(); cy.get( '#submit' ).click(); } ); @@ -81,9 +83,9 @@ describe( '[Language processing] Speech to Text Tests', () => { // Disable features cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_whisper' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_audio_transcripts_generation' ); - cy.get( '#enable_transcripts' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -91,9 +93,9 @@ describe( '[Language processing] Speech to Text Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_whisper' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_audio_transcripts_generation' ); - cy.get( '#enable_transcripts' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -103,9 +105,9 @@ describe( '[Language processing] Speech to Text Tests', () => { it( 'Can enable/disable speech to text feature by role', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_whisper' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_audio_transcripts_generation' ); - cy.get( '#enable_transcripts' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); const options = { @@ -114,21 +116,17 @@ describe( '[Language processing] Speech to Text Tests', () => { }; // Disable admin role. - cy.disableFeatureForRoles( - 'speech_to_text', - [ 'administrator' ], - 'openai_whisper' - ); + cy.disableFeatureForRoles( 'feature_audio_transcripts_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifySpeechToTextEnabled( false, options ); // Enable admin role. - cy.enableFeatureForRoles( - 'speech_to_text', - [ 'administrator' ], - 'openai_whisper' - ); + cy.enableFeatureForRoles( 'feature_audio_transcripts_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifySpeechToTextEnabled( true, options ); @@ -141,21 +139,17 @@ describe( '[Language processing] Speech to Text Tests', () => { }; // Disable admin role. - cy.disableFeatureForRoles( - 'speech_to_text', - [ 'administrator' ], - 'openai_whisper' - ); + cy.disableFeatureForRoles( 'feature_audio_transcripts_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifySpeechToTextEnabled( false, options ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'speech_to_text', - [ 'admin' ], - 'openai_whisper' - ); + cy.enableFeatureForUsers( 'feature_audio_transcripts_generation', [ + 'admin', + ] ); // Verify that the feature is available. cy.verifySpeechToTextEnabled( true, options ); @@ -168,16 +162,16 @@ describe( '[Language processing] Speech to Text Tests', () => { }; // Enable user based opt-out. - cy.enableFeatureOptOut( 'speech_to_text', 'openai_whisper' ); + cy.enableFeatureOptOut( 'feature_audio_transcripts_generation' ); // opt-out - cy.optOutFeature( 'speech_to_text' ); + cy.optOutFeature( 'feature_audio_transcripts_generation' ); // Verify that the feature is not available. cy.verifySpeechToTextEnabled( false, options ); // opt-in - cy.optInFeature( 'speech_to_text' ); + cy.optInFeature( 'feature_audio_transcripts_generation' ); // Verify that the feature is available. cy.verifySpeechToTextEnabled( true, options ); diff --git a/tests/cypress/integration/language-processing/text-to-speech-microsoft-azure.test.js b/tests/cypress/integration/language-processing/text-to-speech-microsoft-azure.test.js index cfc4d24cd..e6863a18f 100644 --- a/tests/cypress/integration/language-processing/text-to-speech-microsoft-azure.test.js +++ b/tests/cypress/integration/language-processing/text-to-speech-microsoft-azure.test.js @@ -2,13 +2,15 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => before( () => { cy.login(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=azure_text_to_speech' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_text_to_speech_generation' ); - cy.get( '#azure_text_to_speech_post_types_post' ).check( 'post' ); - cy.get( '#url' ).clear(); - cy.get( '#url' ).type( 'https://service.com' ); + cy.get( + '#classifai_feature_text_to_speech_generation_post_types_post' + ).check( 'post' ); + cy.get( '#endpoint_url' ).clear(); + cy.get( '#endpoint_url' ).type( 'https://service.com' ); cy.get( '#api_key' ).type( 'password' ); - cy.get( '#enable_text_to_speech' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); cy.get( '#voice' ).select( 'en-AU-AnnetteNeural|Female' ); @@ -110,9 +112,11 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => it( 'Disable support for post type Post', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=azure_text_to_speech' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_text_to_speech_generation' ); - cy.get( '#azure_text_to_speech_post_types_post' ).uncheck( 'post' ); + cy.get( + '#classifai_feature_text_to_speech_generation_post_types_post' + ).uncheck( 'post' ); cy.get( '#submit' ).click(); cy.visit( '/text-to-speech-test/' ); @@ -122,9 +126,9 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => it( 'Can enable/disable text to speech feature', () => { // Disable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=azure_text_to_speech' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_text_to_speech_generation' ); - cy.get( '#enable_text_to_speech' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -132,10 +136,12 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=azure_text_to_speech' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_text_to_speech_generation' ); - cy.get( '#enable_text_to_speech' ).check(); - cy.get( '#azure_text_to_speech_post_types_post' ).check( 'post' ); + cy.get( '#status' ).check(); + cy.get( + '#classifai_feature_text_to_speech_generation_post_types_post' + ).check( 'post' ); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -145,27 +151,25 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => it( 'Can enable/disable text to speech feature by role', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=azure_text_to_speech' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_text_to_speech_generation' ); - cy.get( '#azure_text_to_speech_post_types_post' ).check( 'post' ); + cy.get( + '#classifai_feature_text_to_speech_generation_post_types_post' + ).check( 'post' ); cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'text_to_speech', - [ 'administrator' ], - 'azure_text_to_speech' - ); + cy.disableFeatureForRoles( 'feature_text_to_speech_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyTextToSpeechEnabled( false ); // Enable admin role. - cy.enableFeatureForRoles( - 'text_to_speech', - [ 'administrator' ], - 'azure_text_to_speech' - ); + cy.enableFeatureForRoles( 'feature_text_to_speech_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyTextToSpeechEnabled( true ); @@ -173,21 +177,17 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => it( 'Can enable/disable text to speech feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'text_to_speech', - [ 'administrator' ], - 'azure_text_to_speech' - ); + cy.disableFeatureForRoles( 'feature_text_to_speech_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyTextToSpeechEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'text_to_speech', - [ 'admin' ], - 'azure_text_to_speech' - ); + cy.enableFeatureForUsers( 'feature_text_to_speech_generation', [ + 'admin', + ] ); // Verify that the feature is available. cy.verifyTextToSpeechEnabled( true ); @@ -195,16 +195,16 @@ describe( '[Language Processing] Text to Speech (Microsoft Azure) Tests', () => it( 'User can opt-out text to speech feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'text_to_speech', 'azure_text_to_speech' ); + cy.enableFeatureOptOut( 'feature_text_to_speech_generation' ); // opt-out - cy.optOutFeature( 'text_to_speech' ); + cy.optOutFeature( 'feature_text_to_speech_generation' ); // Verify that the feature is not available. cy.verifyTextToSpeechEnabled( false ); // opt-in - cy.optInFeature( 'text_to_speech' ); + cy.optInFeature( 'feature_text_to_speech_generation' ); // Verify that the feature is available. cy.verifyTextToSpeechEnabled( true ); diff --git a/tests/cypress/integration/language-processing/title-generation-openapi-chatgpt.test.js b/tests/cypress/integration/language-processing/title-generation-openapi-chatgpt.test.js index 98f3f21bd..05ae7e787 100644 --- a/tests/cypress/integration/language-processing/title-generation-openapi-chatgpt.test.js +++ b/tests/cypress/integration/language-processing/title-generation-openapi-chatgpt.test.js @@ -13,15 +13,15 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'Can save OpenAI ChatGPT "Language Processing" title settings', () => { cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); cy.get( '#api_key' ).clear().type( 'password' ); - cy.get( '#enable_titles' ).check(); + cy.get( '#status' ).check(); cy.get( - '#openai_chatgpt_title_generation_roles_administrator' + '#classifai_feature_title_generation_roles_administrator' ).check(); - cy.get( '#number_titles' ).select( 1 ); + cy.get( '#number_of_titles' ).type( 1 ); cy.get( '#submit' ).click(); } ); @@ -92,9 +92,9 @@ describe( '[Language processing] Title Generation Tests', () => { cy.enableClassicEditor(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); - cy.get( '#enable_titles' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); const data = getChatGPTData(); @@ -118,12 +118,12 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'Can set multiple custom title generation prompts, select one as the default and delete one.', () => { cy.disableClassicEditor(); cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); // Add three custom prompts. cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][0][default]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][0][default]"]' ) .parents( 'td:first' ) .find( 'button.js-classifai-add-prompt-fieldset' ) @@ -131,7 +131,7 @@ describe( '[Language processing] Title Generation Tests', () => { .click() .click(); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][0][default]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -139,40 +139,40 @@ describe( '[Language processing] Title Generation Tests', () => { // Set the data for each prompt. cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][1][title]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][1][title]"]' ) .clear() .type( 'First custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][1][prompt]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][1][prompt]"]' ) .clear() .type( 'This is our first custom title prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][2][title]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][2][title]"]' ) .clear() .type( 'Second custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][2][prompt]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][2][prompt]"]' ) .clear() .type( 'This prompt should be deleted' ); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][3][title]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][3][title]"]' ) .clear() .type( 'Third custom prompt' ); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][3][prompt]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][3][prompt]"]' ) .clear() .type( 'This is a custom title prompt' ); // Set the third prompt as our default. cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][3][default]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][3][default]"]' ) .parent() .find( 'a.action__set_default' ) @@ -180,7 +180,7 @@ describe( '[Language processing] Title Generation Tests', () => { // Delete the second prompt. cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][2][default]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][2][default]"]' ) .parent() .find( 'a.action__remove_prompt' ) @@ -189,7 +189,7 @@ describe( '[Language processing] Title Generation Tests', () => { .find( '.button-primary' ) .click(); cy.get( - '[name="classifai_openai_chatgpt[generate_title_prompt][0][default]"]' + '[name="classifai_feature_title_generation[generate_title_prompt][0][default]"]' ) .parents( 'td:first' ) .find( '.classifai-field-type-prompt-setting' ) @@ -262,9 +262,9 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'Can enable/disable title generation feature', () => { // Disable features. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); - cy.get( '#enable_titles' ).uncheck(); + cy.get( '#status' ).uncheck(); cy.get( '#submit' ).click(); // Verify that the feature is not available. @@ -272,9 +272,9 @@ describe( '[Language processing] Title Generation Tests', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); - cy.get( '#enable_titles' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Verify that the feature is available. @@ -284,27 +284,23 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'Can enable/disable title generation feature by role', () => { // Enable feature. cy.visit( - '/wp-admin/tools.php?page=classifai&tab=language_processing&provider=openai_chatgpt' + '/wp-admin/tools.php?page=classifai&tab=language_processing&feature=feature_title_generation' ); - cy.get( '#enable_titles' ).check(); + cy.get( '#status' ).check(); cy.get( '#submit' ).click(); // Disable admin role. - cy.disableFeatureForRoles( - 'title_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_title_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyTitleGenerationEnabled( false ); // Enable admin role. - cy.enableFeatureForRoles( - 'title_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.enableFeatureForRoles( 'feature_title_generation', [ + 'administrator', + ] ); // Verify that the feature is available. cy.verifyTitleGenerationEnabled( true ); @@ -312,21 +308,15 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'Can enable/disable title generation feature by user', () => { // Disable admin role. - cy.disableFeatureForRoles( - 'title_generation', - [ 'administrator' ], - 'openai_chatgpt' - ); + cy.disableFeatureForRoles( 'feature_title_generation', [ + 'administrator', + ] ); // Verify that the feature is not available. cy.verifyTitleGenerationEnabled( false ); // Enable feature for admin user. - cy.enableFeatureForUsers( - 'title_generation', - [ 'admin' ], - 'openai_chatgpt' - ); + cy.enableFeatureForUsers( 'feature_title_generation', [ 'admin' ] ); // Verify that the feature is available. cy.verifyTitleGenerationEnabled( true ); @@ -334,16 +324,16 @@ describe( '[Language processing] Title Generation Tests', () => { it( 'User can opt-out title generation feature', () => { // Enable user based opt-out. - cy.enableFeatureOptOut( 'title_generation', 'openai_chatgpt' ); + cy.enableFeatureOptOut( 'feature_title_generation' ); // opt-out - cy.optOutFeature( 'title_generation' ); + cy.optOutFeature( 'feature_title_generation' ); // Verify that the feature is not available. cy.verifyTitleGenerationEnabled( false ); // opt-in - cy.optInFeature( 'title_generation' ); + cy.optInFeature( 'feature_title_generation' ); // Verify that the feature is available. cy.verifyTitleGenerationEnabled( true ); diff --git a/tests/cypress/support/commands.js b/tests/cypress/support/commands.js index facdfcbea..115eeb089 100644 --- a/tests/cypress/support/commands.js +++ b/tests/cypress/support/commands.js @@ -126,17 +126,16 @@ Cypress.Commands.add( 'optInAllFeatures', () => { /** * Enable role based access for a feature. * - * @param {string} feature The feature to enable. - * @param {string} roles The roles to enable. - * @param {string} provider The provider to enable. + * @param {string} feature The feature to enable. + * @param {string} roles The roles to enable. */ -Cypress.Commands.add( 'enableFeatureForRoles', ( feature, roles, provider ) => { +Cypress.Commands.add( 'enableFeatureForRoles', ( feature, roles ) => { cy.visit( - `/wp-admin/tools.php?page=classifai&tab=language_processing&provider=${ provider }` + `/wp-admin/tools.php?page=classifai&tab=language_processing&feature=${ feature }` ); - cy.get( `#${ feature }_role_based_access` ).check(); + cy.get( `#role_based_access` ).check(); roles.forEach( ( role ) => { - cy.get( `#${ provider }_${ feature }_roles_${ role }` ).check(); + cy.get( `#classifai_${ feature }_roles_${ role }` ).check(); } ); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -145,46 +144,40 @@ Cypress.Commands.add( 'enableFeatureForRoles', ( feature, roles, provider ) => { /** * Disable role based access for a feature. * - * @param {string} feature The feature to disable. - * @param {string} roles The roles to disable. - * @param {string} provider The provider to disable. + * @param {string} feature The feature to disable. + * @param {string} roles The roles to disable. */ -Cypress.Commands.add( - 'disableFeatureForRoles', - ( feature, roles, provider ) => { - cy.visit( - `/wp-admin/tools.php?page=classifai&tab=language_processing&provider=${ provider }` - ); - cy.get( `#${ feature }_role_based_access` ).check(); - roles.forEach( ( role ) => { - cy.get( `#${ provider }_${ feature }_roles_${ role }` ).uncheck(); - } ); - cy.get( '#submit' ).click(); - cy.get( '.notice' ).contains( 'Settings saved.' ); - } -); +Cypress.Commands.add( 'disableFeatureForRoles', ( feature, roles ) => { + cy.visit( + `/wp-admin/tools.php?page=classifai&tab=language_processing&feature=${ feature }` + ); + cy.get( '#status' ).check(); + cy.get( `#role_based_access` ).check(); + roles.forEach( ( role ) => { + cy.get( `#classifai_${ feature }_roles_${ role }` ).uncheck(); + } ); + cy.get( '#submit' ).click(); + cy.get( '.notice' ).contains( 'Settings saved.' ); +} ); /** * Enable user based access for a feature. * - * @param {string} feature The feature to enable. - * @param {string} users The users to enable. - * @param {string} provider The provider to enable. + * @param {string} feature The feature to enable. + * @param {string} users The users to enable. */ -Cypress.Commands.add( 'enableFeatureForUsers', ( feature, users, provider ) => { +Cypress.Commands.add( 'enableFeatureForUsers', ( feature, users ) => { cy.visit( - `/wp-admin/tools.php?page=classifai&tab=language_processing&provider=${ provider }` + `/wp-admin/tools.php?page=classifai&tab=language_processing&feature=${ feature }` ); - cy.get( `#${ feature }_user_based_access` ).check(); - cy.get( 'body' ).then( ( $body ) => { + cy.get( `#user_based_access` ).check(); + cy.wait( 1000 ); + cy.get( '.allowed_users_row' ).then( ( $body ) => { if ( - $body.find( - `#${ feature }_users-container .components-form-token-field__remove-token` - ).length > 0 + $body.find( `.components-form-token-field__remove-token` ).length > + 0 ) { - cy.get( - `#${ feature }_users-container .components-form-token-field__remove-token` - ).click( { + cy.get( `.components-form-token-field__remove-token` ).click( { multiple: true, } ); } @@ -192,12 +185,10 @@ Cypress.Commands.add( 'enableFeatureForUsers', ( feature, users, provider ) => { users.forEach( ( user ) => { cy.get( - `#${ feature }_users-container input.components-form-token-field__input` + `.allowed_users_row input.components-form-token-field__input` ).type( user ); - cy.wait( 1000 ); - cy.get( - 'ul.components-form-token-field__suggestions-list li:nth-child(1)' - ).click(); + + cy.get( '[aria-label="admin (admin)"]' ).click(); } ); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -206,17 +197,16 @@ Cypress.Commands.add( 'enableFeatureForUsers', ( feature, users, provider ) => { /** * Enable user based opt-out for a feature. * - * @param {string} feature The feature to enable. - * @param {string} provider The provider to enable. + * @param {string} feature The feature to enable. */ -Cypress.Commands.add( 'enableFeatureOptOut', ( feature, provider ) => { +Cypress.Commands.add( 'enableFeatureOptOut', ( feature ) => { cy.visit( - `/wp-admin/tools.php?page=classifai&tab=language_processing&provider=${ provider }` + `/wp-admin/tools.php?page=classifai&tab=language_processing&feature=${ feature }` ); - cy.get( `#${ feature }_role_based_access` ).check(); - cy.get( `#${ provider }_${ feature }_roles_administrator` ).check(); - cy.get( `#${ feature }_user_based_access` ).uncheck(); - cy.get( `#${ feature }_user_based_opt_out` ).check(); + cy.get( `#role_based_access` ).check(); + cy.get( `#classifai_${ feature }_roles_administrator` ).check(); + cy.get( `#user_based_access` ).uncheck(); + cy.get( `#user_based_opt_out` ).check(); cy.get( '#submit' ).click(); cy.get( '.notice' ).contains( 'Settings saved.' ); @@ -324,10 +314,15 @@ Cypress.Commands.add( */ Cypress.Commands.add( 'verifyTextToSpeechEnabled', ( enabled = true ) => { const shouldExist = enabled ? 'exist' : 'not.exist'; + cy.visit( '/wp-admin/edit.php' ); cy.get( '#the-list tr:nth-child(1) td.title a.row-title' ).click(); cy.closeWelcomeGuide(); - cy.get( '.classifai-panel' ).click(); + cy.get( 'body' ).then( ( $body ) => { + if ( $body.find( '.classifai-panel' ).length ) { + $body.find( '.classifai-panel' ).click(); + } + } ); cy.get( '#classifai-audio-controls__preview-btn' ).should( shouldExist ); } ); @@ -417,17 +412,17 @@ Cypress.Commands.add( const shouldExist = enabled ? 'exist' : 'not.exist'; // Verify with Image processing features in attachment metabox. cy.visit( options.imageEditLink ); - cy.get( '.misc-publishing-actions label[for=rescan-captions]' ).should( - shouldExist - ); - cy.get( '.misc-publishing-actions label[for=rescan-tags]' ).should( + cy.get( + '#classifai_image_processing label[for=rescan-captions]' + ).should( shouldExist ); + cy.get( '#classifai_image_processing label[for=rescan-tags]' ).should( shouldExist ); - cy.get( '.misc-publishing-actions label[for=rescan-ocr]' ).should( + cy.get( '#classifai_image_processing label[for=rescan-ocr]' ).should( shouldExist ); cy.get( - '.misc-publishing-actions label[for=rescan-smart-crop]' + '#classifai_image_processing label[for=rescan-smart-crop]' ).should( shouldExist ); // Verify with Image processing features in media model.