diff --git a/.wiki/Playground-Testing.md b/.wiki/Playground-Testing.md index b50372f..86d11ef 100644 --- a/.wiki/Playground-Testing.md +++ b/.wiki/Playground-Testing.md @@ -17,7 +17,10 @@ The easiest way to test our plugin with WordPress Playground is to use the onlin 1. Single site testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/blueprint.json&_t=4) -2. Multisite testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=13) +2. Multisite testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=14) + - After WordPress loads, go to Settings > General + - Scroll down and check "Allow network access" and "Create a multisite network" + - Click "Apply Settings & Reset Playground" These links will automatically set up WordPress with our plugin installed and activated. @@ -32,7 +35,7 @@ To run tests with WordPress Playground: 1. Open the appropriate WordPress Playground link: - [Single site](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/blueprint.json&_t=4) - - [Multisite](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=13) + - [Multisite](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=14) (requires manual multisite activation) 2. Test the plugin manually in the browser diff --git a/.wiki/Testing.md b/.wiki/Testing.md index a62c9dc..1c2d028 100644 --- a/.wiki/Testing.md +++ b/.wiki/Testing.md @@ -106,7 +106,10 @@ The easiest way to test our plugin with WordPress Playground is to use the onlin 1. Single site testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/blueprint.json&_t=4) -2. Multisite testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=13) +2. Multisite testing: [Open in WordPress Playground](https://playground.wordpress.net/?blueprint-url=https://raw.githubusercontent.com/wpallstars/wp-plugin-starter-template-for-ai-coding/feature/testing-framework/playground/multisite-blueprint.json&_t=14) + - After WordPress loads, go to Settings > General + - Scroll down and check "Allow network access" and "Create a multisite network" + - Click "Apply Settings & Reset Playground" These links will automatically set up WordPress with a sample plugin installed and activated. diff --git a/playground/multisite-blueprint.json b/playground/multisite-blueprint.json index 0f8dedf..645e416 100644 --- a/playground/multisite-blueprint.json +++ b/playground/multisite-blueprint.json @@ -1,83 +1,21 @@ { - "landingPage": "/wp-admin/", + "landingPage": "/wp-admin/options-general.php", "login": true, "preferredVersions": { "php": "8.0", "wp": "latest" }, + "options": { + "multisite": true, + "networking": true + }, "steps": [ - { - "step": "defineWpConfig", - "name": "WP_DEBUG", - "value": true - }, - { - "step": "defineWpConfig", - "name": "WP_DEBUG_LOG", - "value": true - }, - { - "step": "defineWpConfig", - "name": "WP_DEBUG_DISPLAY", - "value": false - }, - { - "step": "runPHP", - "code": " 'WordPress Multisite',\n 'subdomain_install' => false,\n 'domain' => 'localhost',\n 'path' => '/',\n 'email' => 'admin@example.com'\n];\n\nupdate_option('admin_email', $network_data['email']);\n\ntry {\n error_log('Running wp_install_network()...');\n wp_install_network($network_data);\n error_log('Network setup completed successfully');\n} catch (Exception $e) {\n error_log('Network setup error: ' . $e->getMessage());\n}\n" - }, - { - "step": "defineWpConfig", - "name": "MULTISITE", - "value": true - }, - { - "step": "defineWpConfig", - "name": "SUBDOMAIN_INSTALL", - "value": false - }, - { - "step": "defineWpConfig", - "name": "DOMAIN_CURRENT_SITE", - "value": "localhost" - }, - { - "step": "defineWpConfig", - "name": "PATH_CURRENT_SITE", - "value": "/" - }, - { - "step": "defineWpConfig", - "name": "SITE_ID_CURRENT_SITE", - "value": 1 - }, - { - "step": "defineWpConfig", - "name": "BLOG_ID_CURRENT_SITE", - "value": 1 - }, - { - "step": "runPHP", - "code": "get_results('SHOW TABLES LIKE \\'' . $wpdb->prefix . 'site\\';');\nerror_log('Multisite tables found: ' . count($tables));\n\nif (is_multisite()) {\n error_log('Creating test subsite...');\n $domain = 'localhost';\n $path = '/testsite/';\n $title = 'Test Subsite';\n $user_id = 1;\n\n if (!function_exists('get_site_by_path')) {\n require_once('/wordpress/wp-includes/ms-blogs.php');\n }\n\n if (!get_site_by_path($domain, $path)) {\n $blog_id = wpmu_create_blog($domain, $path, $title, $user_id);\n if (is_wp_error($blog_id)) {\n error_log('Subsite creation error: ' . $blog_id->get_error_message());\n } else {\n error_log('Created subsite with ID: ' . $blog_id);\n }\n } else {\n error_log('Subsite already exists');\n }\n}\n" - }, { "step": "installPlugin", "pluginData": { "resource": "wordpress.org/plugins", "slug": "coblocks" } - }, - { - "step": "runPHP", - "code": " - +