Files
MiraviaConnector/platform-middleware-master/test/Services/Mirakl/PlatformSettingTest.php
Miravia Connector Bot 752600f337 Fix image upload structure for Miravia API compliance
🔧 Bug Fixes:
- Fixed product image structure to match Miravia API requirements
- Updated MiraviaProduct.php getData() method to wrap images in {"Image": [...]} format
- Updated MiraviaCombination.php getData() method to wrap SKU images properly
- Resolved error "[4224] The Main image of the product is required"

📋 Changes:
- Modified getData() methods to transform flat image arrays to nested structure
- Product images: images[] → Images: {"Image": [...]}
- SKU images: images[] → Images: {"Image": [...]}
- Maintains backward compatibility for empty image arrays

🎯 Impact:
- Product uploads will now pass Miravia's image validation
- Both product-level and SKU-level images properly formatted
- Complies with official Miravia API documentation structure

🤖 Generated with Claude Code (https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-21 11:34:59 +02:00

31 lines
901 B
PHP

<?php
/**
* Created by Sweeper PhpStorm.
* Author: Sweeper <wili.lixiang@gmail.com>
* DateTime: 2024/2/26 13:50
*/
namespace Sweeper\PlatformMiddleware\Test\Services\Mirakl;
use PHPUnit\Framework\TestCase;
use Sweeper\PlatformMiddleware\Services\Mirakl\PlatformSetting;
use Sweeper\PlatformMiddleware\Services\Mirakl\Request;
class PlatformSettingTest extends TestCase
{
public function testCarriers(): void
{
$response = PlatformSetting::instance([
'api_url' => Request::OPEN_API_URL,
'api_key' => $appInfo['apiKey'] ?? $appInfo['api_key'] ?? $appInfo['secretFieldValue'] ?? '59ac39c9-6d1b-4ff1-a57f-26bb835048e6',
'shop_id' => $appInfo['shopId'] ?? $appInfo['shop_id'] ?? $appInfo['clientFieldValue'] ?? '',
])->setSuccessCode(-1)->carriers();
dump($response);
$this->assertTrue($response->isSuccess());
}
}