Skip to content

Commit

Permalink
MNT Test dynamodb integration works
Browse files Browse the repository at this point in the history
  • Loading branch information
emteknetnz committed Feb 16, 2023
1 parent 6129014 commit e88e99b
Show file tree
Hide file tree
Showing 3 changed files with 92 additions and 1 deletion.
5 changes: 5 additions & 0 deletions code/Model/DynamoDbSession.php
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,11 @@ public function getHandler(): SessionHandler
return $this->handler;
}

public function getClient(): DynamoDbClient
{
return $this->client;
}

/**
* Get an instance of DynamoDbSession configured from the environment if available.
*/
Expand Down
2 changes: 1 addition & 1 deletion phpunit.xml.dist
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
Standard module phpunit configuration.
Requires PHPUnit ^5.7
-->
<phpunit bootstrap="vendor/silverstripe/framework/tests/bootstrap.php" colors="true">
<phpunit bootstrap="vendor/silverstripe/framework/tests/bootstrap.php" colors="true" stderr="true">
<testsuite name="Default">
<directory>tests/</directory>
</testsuite>
Expand Down
86 changes: 86 additions & 0 deletions tests/DynamoDbSessionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,11 @@
use SilverStripe\Core\Environment;
use SilverStripe\Dev\SapphireTest;
use SilverStripe\DynamoDb\Model\DynamoDbSession;
use Aws\DynamoDb\DynamoDbClient;
use SilverStripe\Control\Session;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\Cookie;
use Exception;

class DynamoDbSessionTest extends SapphireTest
{
Expand Down Expand Up @@ -61,4 +66,85 @@ public function testGetSessionHandler()
$handler = $sess->getHandler();
$this->assertInstanceOf('\\Aws\\DynamoDb\\SessionHandler', $handler);
}

private function getSessions(DynamoDbClient $client, string $tableName): array
{
return $client->scan([
'TableName' => $tableName,
])->get('Items');
}

/**
* This test requires the strerr="true" attribute in phpunit.xml.dist to be set otherwise
* you'll get a failure because of
* "session_set_save_handler(): Session save handler cannot be changed after headers have already been sent"
*/
public function testSessionsAreStoredInDynamoDB()
{
$tableName = 'unit-test-mysession';

$dynamoDbSession = new DynamoDbSession([
'endpoint' => Environment::getEnv('AWS_DYNAMODB_ENDPOINT'),
'region' => Environment::getEnv('AWS_REGION_NAME'),
'credentials' => [
'key' => Environment::getEnv('AWS_ACCESS_KEY'),
'secret' => Environment::getEnv('AWS_SECRET_KEY')
]
], $tableName);
$dynamoDbSession->register();
$client = $dynamoDbSession->getClient();

$result = $client->listTables();
// Delete any pre-existing session table (may still be there from failed unit test)
foreach ($result['TableNames'] ?? [] as $resultTableName) {
if ($resultTableName === $tableName) {
$client->deleteTable([
'TableName' => $tableName,
]);
}
}

// Create new session table
$client->createTable([
'TableName' => $tableName,
'AttributeDefinitions' => [
[
'AttributeName' => 'id',
'AttributeType' => 'S'
],
],
'KeySchema' => [
[
'AttributeName' => 'id',
'KeyType' => 'HASH'
]
],
'ProvisionedThroughput' => [
'ReadCapacityUnits' => 1,
'WriteCapacityUnits' => 1
],
]);

$sessions = $this->getSessions($client, $tableName);
$this->assertSame(0, count($sessions));

// Start a new session in Silverstripe
Session::config()->set('strict_user_agent_check', false);
$req = new HTTPRequest('GET', '/');
Cookie::set(session_name(), '1234');
$session = new Session(null);
$session->init($req);
$sessionID = session_id();
// Session has to close for the data to be written to dynamodb
session_write_close();

$sessions = $this->getSessions($client, $tableName);
$this->assertSame(1, count($sessions));
$this->assertStringContainsString($sessionID, $sessions[0]['id']['S']);

// Delete the dynamodb table
$client->deleteTable([
'TableName' => $tableName,
]);
}
}

0 comments on commit e88e99b

Please sign in to comment.