feat: expand admin sync settings
This commit is contained in:
@@ -57,6 +57,53 @@ class SettingsTest extends TestCase {
|
||||
self::assertTrue( $settings->automaticUrlReplacementEnabled() );
|
||||
}
|
||||
|
||||
public function test_it_sanitizes_full_admin_workflow_settings(): void {
|
||||
$settings = Settings::fromArray(
|
||||
array(
|
||||
'sync_pairs' => array(
|
||||
array(
|
||||
'name' => '<b>Production to Staging</b>',
|
||||
'source_url' => 'https://example.test/',
|
||||
'destination_url' => 'https://staging.example.test/',
|
||||
'username' => '<script>codex</script>',
|
||||
'application_password' => 'secret app password',
|
||||
'default_direction' => 'push',
|
||||
'content_types' => array( 'posts', 'terms', 'media', 'bad_type' ),
|
||||
'url_mappings' => array(
|
||||
array(
|
||||
'source' => 'https://example.test',
|
||||
'destination' => 'https://staging.example.test',
|
||||
),
|
||||
),
|
||||
),
|
||||
),
|
||||
'log_retention' => '50',
|
||||
'debug_logging' => '1',
|
||||
)
|
||||
);
|
||||
|
||||
$pairs = $settings->syncPairs();
|
||||
|
||||
self::assertSame( 'Production to Staging', $pairs[0]['name'] );
|
||||
self::assertSame( 'https://example.test/', $pairs[0]['source_url'] );
|
||||
self::assertSame( 'https://staging.example.test/', $pairs[0]['destination_url'] );
|
||||
self::assertSame( 'codex', $pairs[0]['username'] );
|
||||
self::assertSame( 'secret app password', $pairs[0]['application_password'] );
|
||||
self::assertSame( 'push', $pairs[0]['default_direction'] );
|
||||
self::assertSame( array( 'posts', 'terms', 'media' ), $pairs[0]['content_types'] );
|
||||
self::assertSame(
|
||||
array(
|
||||
array(
|
||||
'source' => 'https://example.test',
|
||||
'destination' => 'https://staging.example.test',
|
||||
),
|
||||
),
|
||||
$pairs[0]['url_mappings']
|
||||
);
|
||||
self::assertSame( 50, $settings->logRetention() );
|
||||
self::assertTrue( $settings->debugLoggingEnabled() );
|
||||
}
|
||||
|
||||
public function test_it_serializes_to_array(): void {
|
||||
$settings = Settings::fromArray(
|
||||
array(
|
||||
@@ -74,14 +121,21 @@ class SettingsTest extends TestCase {
|
||||
array(
|
||||
'sync_pairs' => array(
|
||||
array(
|
||||
'name' => 'Staging',
|
||||
'source_url' => 'https://example.test',
|
||||
'destination_url' => 'https://staging.example.test',
|
||||
'name' => 'Staging',
|
||||
'source_url' => 'https://example.test',
|
||||
'destination_url' => 'https://staging.example.test',
|
||||
'username' => '',
|
||||
'application_password' => '',
|
||||
'default_direction' => 'push',
|
||||
'content_types' => array( 'posts', 'terms', 'media', 'custom_post_types' ),
|
||||
'url_mappings' => array(),
|
||||
),
|
||||
),
|
||||
'logging_level' => 'warning',
|
||||
'automatic_url_replacement' => true,
|
||||
'conflict_strategy' => 'last_write_wins',
|
||||
'log_retention' => 200,
|
||||
'debug_logging' => false,
|
||||
),
|
||||
$settings->toArray()
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user