✅ Fixed bulk conversion getting stuck on missing files ✅ Added robust error handling and timeout protection ✅ Improved JavaScript response parsing ✅ Added file existence validation ✅ Fixed missing PHP class imports ✅ Added comprehensive try-catch error recovery 🔧 Key fixes: - File existence checks before conversion attempts - 30-second timeout protection per file - Graceful handling of 500 errors and JSON parsing issues - Automatic continuation to next file on failures - Cache busting for JavaScript updates 🎯 Result: Bulk conversion now completes successfully even with missing files 🚀 Generated with Claude Code (https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
99 lines
2.6 KiB
PHP
99 lines
2.6 KiB
PHP
<?php
|
|
/*
|
|
subdir: rewrite
|
|
files:
|
|
- filename: '.htaccess'
|
|
content: |
|
|
<IfModule mod_rewrite.c>
|
|
RewriteEngine On
|
|
RewriteRule ^0\.txt$ 1\.txt [L]
|
|
</IfModule>
|
|
- filename: '0.txt'
|
|
content: '0'
|
|
- filename: '1.txt'
|
|
content: '1'
|
|
|
|
request:
|
|
url: '0.txt'
|
|
|
|
interpretation:
|
|
- [success, body, equals, '1']
|
|
- [failure, body, equals, '0']
|
|
|
|
|
|
----
|
|
|
|
Tested:
|
|
|
|
Server setup | Test result
|
|
--------------------------------------------------
|
|
.htaccess disabled | failure
|
|
forbidden directives (fatal) | failure
|
|
access denied | inconclusive (it might be allowed to other files)
|
|
directive has no effect | failure
|
|
| success
|
|
*/
|
|
|
|
|
|
namespace HtaccessCapabilityTester\Tests\Testers;
|
|
|
|
use HtaccessCapabilityTester\HttpResponse;
|
|
use HtaccessCapabilityTester\Testers\RewriteTester;
|
|
use HtaccessCapabilityTester\Tests\FakeServer;
|
|
use PHPUnit\Framework\TestCase;
|
|
|
|
class RewriteTesterTest extends BasisTestCase
|
|
{
|
|
|
|
public function testHtaccessDisabled()
|
|
{
|
|
$fakeServer = new FakeServer();
|
|
$fakeServer->disableHtaccess();
|
|
$testResult = $fakeServer->runTester(new RewriteTester());
|
|
$this->assertFailure($testResult);
|
|
}
|
|
|
|
public function testDisallowedDirectivesFatal()
|
|
{
|
|
$fakeServer = new FakeServer();
|
|
$fakeServer->disallowAllDirectives('fatal');
|
|
$testResult = $fakeServer->runTester(new RewriteTester());
|
|
$this->assertFailure($testResult);
|
|
}
|
|
|
|
public function testAccessAllDenied()
|
|
{
|
|
$fakeServer = new FakeServer();
|
|
$fakeServer->denyAllAccess();
|
|
$testResult = $fakeServer->runTester(new RewriteTester());
|
|
$this->assertInconclusive($testResult);
|
|
}
|
|
|
|
/**
|
|
* Test when the directive has no effect.
|
|
* This could happen when:
|
|
* - The directive is forbidden (non-fatal)
|
|
* - The module is not loaded
|
|
*/
|
|
public function testDirectiveHasNoEffect()
|
|
{
|
|
$fakeServer = new FakeServer();
|
|
$fakeServer->setResponses([
|
|
'/rewrite/0.txt' => new HttpResponse('0', '200', [])
|
|
]);
|
|
$testResult = $fakeServer->runTester(new RewriteTester());
|
|
$this->assertFailure($testResult);
|
|
}
|
|
|
|
public function testSuccess()
|
|
{
|
|
$fakeServer = new FakeServer();
|
|
$fakeServer->setResponses([
|
|
'/rewrite/0.txt' => new HttpResponse('1', '200', [])
|
|
]);
|
|
$testResult = $fakeServer->runTester(new RewriteTester());
|
|
$this->assertSuccess($testResult);
|
|
}
|
|
|
|
}
|