2 Commits
0.9 ... main

16 changed files with 1214 additions and 742 deletions

3
.gitignore vendored
View File

@@ -4,4 +4,5 @@ cache
.cache .cache
.config .config
.local .local
*.phar *.phar
.composer

1
.phpunit.result.cache Normal file

File diff suppressed because one or more lines are too long

View File

@@ -2,7 +2,7 @@
"name": "cloudobjects/sdk", "name": "cloudobjects/sdk",
"description": "CloudObjects SDK for PHP for working with COIDs and object descriptions from CloudObjects.", "description": "CloudObjects SDK for PHP for working with COIDs and object descriptions from CloudObjects.",
"keywords": ["cloudobjects", "sdk"], "keywords": ["cloudobjects", "sdk"],
"homepage": "https://github.com/CloudObjects/CloudObjects-PHP-SDK", "homepage": "https://codeberg.org/CloudObjects/CloudObjects-PHP-SDK",
"license": "MPL-2.0", "license": "MPL-2.0",
"require" : { "require" : {
"ml/json-ld": ">=1.0.7", "ml/json-ld": ">=1.0.7",
@@ -10,7 +10,7 @@
"doctrine/cache" : "1.*", "doctrine/cache" : "1.*",
"guzzlehttp/guzzle" : ">=6.0", "guzzlehttp/guzzle" : ">=6.0",
"psr/log": ">=1.1", "psr/log": ">=1.1",
"kevinrob/guzzle-cache-middleware": "^3.2", "kevinrob/guzzle-cache-middleware": "^7.0.0",
"webmozart/assert": "^1.6" "webmozart/assert": "^1.6"
}, },
"authors": [ "authors": [
@@ -24,16 +24,16 @@
} }
}, },
"require-dev" : { "require-dev" : {
"phpunit/phpunit": ">=4.8.0,<5.0", "phpunit/phpunit": "^10",
"symfony/http-foundation" : ">=4.0", "symfony/http-foundation" : ">=4.0",
"symfony/psr-http-message-bridge" : ">=1.1.0", "symfony/psr-http-message-bridge" : ">=1.1.0",
"nyholm/psr7" : "~1.5.1", "nyholm/psr7" : "~1.5.1",
"defuse/php-encryption" : "^2.2" "defuse/php-encryption" : "^2.2"
}, },
"suggest" : { "suggest" : {
"symfony/http-foundation" : "Required to use parseSymfonyRequest() in AccountContext.", "symfony/http-foundation" : "Required to use fromSymfonyRequest() in AccountContext.",
"symfony/psr-http-message-bridge" : "Required to use parseSymfonyRequest() in AccountContext.", "symfony/psr-http-message-bridge" : "Required to use fromSymfonyRequest() in AccountContext.",
"nyholm/psr7" : "Required to use parseSymfonyRequest() in AccountContext.", "nyholm/psr7" : "Required to use fromSymfonyRequest() in AccountContext.",
"defuse/php-encryption": "Required to use CryptoHelper" "defuse/php-encryption": "Required to use CryptoHelper"
} }
} }

1870
composer.lock generated

File diff suppressed because it is too large Load Diff

View File

@@ -1,13 +1,8 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<phpunit backupGlobals="false" <phpunit backupGlobals="false"
backupStaticAttributes="false"
colors="true" colors="true"
convertErrorsToExceptions="true"
convertNoticesToExceptions="true"
convertWarningsToExceptions="true"
processIsolation="false" processIsolation="false"
stopOnFailure="false" stopOnFailure="false"
syntaxCheck="false"
bootstrap="./tests/bootstrap.php"> bootstrap="./tests/bootstrap.php">
<testsuites> <testsuites>
<testsuite name="OfflineTests"> <testsuite name="OfflineTests">

5
run-docker.sh Normal file
View File

@@ -0,0 +1,5 @@
docker run -d -v .:/root --name cloudobjects-sdk-test cloudobjects/php-build-base:8.3
docker exec cloudobjects-sdk-test bash -c "cd /root && composer install"
docker exec cloudobjects-sdk-test bash -c "cd /root && vendor/bin/phpunit"
docker stop cloudobjects-sdk-test
docker rm cloudobjects-sdk-test

View File

@@ -8,7 +8,7 @@ namespace CloudObjects\SDK\AccountGateway;
use ML\IRI\IRI; use ML\IRI\IRI;
class AAUIDParserTest extends \PHPUnit_Framework_TestCase { class AAUIDParserTest extends \PHPUnit\Framework\TestCase {
public function testValidAccountAAUID() { public function testValidAccountAAUID() {
$aauid = new IRI('aauid:abcd1234abcd1234'); $aauid = new IRI('aauid:abcd1234abcd1234');

View File

@@ -9,7 +9,7 @@ namespace CloudObjects\SDK\AccountGateway;
use GuzzleHttp\Psr7\Request as GuzzlePsrRequest; use GuzzleHttp\Psr7\Request as GuzzlePsrRequest;
use Symfony\Component\HttpFoundation\Request as SymfonyRequest; use Symfony\Component\HttpFoundation\Request as SymfonyRequest;
class AccountContextParseTest extends \PHPUnit_Framework_TestCase { class AccountContextParseTest extends \PHPUnit\Framework\TestCase {
public function testParsePsrRequest() { public function testParsePsrRequest() {
$request = new GuzzlePsrRequest('GET', '/', [ $request = new GuzzlePsrRequest('GET', '/', [

View File

@@ -8,11 +8,11 @@ namespace CloudObjects\SDK\AccountGateway;
use ML\IRI\IRI; use ML\IRI\IRI;
class AccountContextTest extends \PHPUnit_Framework_TestCase { class AccountContextTest extends \PHPUnit\Framework\TestCase {
private $context; private $context;
protected function setUp() { protected function setUp(): void {
$this->context = new AccountContext(new IRI('aauid:aaaabbbbccccdddd'), 'DUMMY'); $this->context = new AccountContext(new IRI('aauid:aaaabbbbccccdddd'), 'DUMMY');
} }

View File

@@ -8,7 +8,7 @@ namespace CloudObjects\SDK;
use ML\IRI\IRI; use ML\IRI\IRI;
class COIDParserTest extends \PHPUnit_Framework_TestCase { class COIDParserTest extends \PHPUnit\Framework\TestCase {
public function testRootCOID() { public function testRootCOID() {
$coid = new IRI('coid://example.com'); $coid = new IRI('coid://example.com');

View File

@@ -11,7 +11,7 @@ use GuzzleHttp\Client, GuzzleHttp\Handler\MockHandler,
GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response; GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response;
use CloudObjects\SDK\ObjectRetriever; use CloudObjects\SDK\ObjectRetriever;
class CryptoHelperTest extends \PHPUnit_Framework_TestCase { class CryptoHelperTest extends \PHPUnit\Framework\TestCase {
private $retriever; private $retriever;
private $graph; private $graph;
@@ -22,7 +22,7 @@ class CryptoHelperTest extends \PHPUnit_Framework_TestCase {
$this->retriever->setClient(new Client(['handler' => $handler])); $this->retriever->setClient(new Client(['handler' => $handler]));
} }
public function setUp() { protected function setUp(): void {
$this->retriever = new ObjectRetriever([ $this->retriever = new ObjectRetriever([
'auth_ns' => 'test.cloudobjects.io', 'auth_ns' => 'test.cloudobjects.io',
'auth_secret' => 'TEST' 'auth_secret' => 'TEST'

View File

@@ -10,12 +10,12 @@ use InvalidArgumentException;
use ML\JsonLD\JsonLD; use ML\JsonLD\JsonLD;
use CloudObjects\SDK\ObjectRetriever; use CloudObjects\SDK\ObjectRetriever;
class SchemaValidatorTest extends \PHPUnit_Framework_TestCase { class SchemaValidatorTest extends \PHPUnit\Framework\TestCase {
private $schemaValidator; private $schemaValidator;
private $graph; private $graph;
public function setUp() { protected function setUp(): void {
$this->schemaValidator = new SchemaValidator(new ObjectRetriever); $this->schemaValidator = new SchemaValidator(new ObjectRetriever);
$this->graph = JsonLD::getDocument('{}')->getGraph(); $this->graph = JsonLD::getDocument('{}')->getGraph();
} }
@@ -24,10 +24,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/String')); $node->setType($this->graph->createNode('coid://json.co-n.net/String'));
$this->schemaValidator->validateAgainstNode("Test", $node); $this->schemaValidator->validateAgainstNode("Test", $node);
$this->addToAssertionCount(1);
} }
public function testNotString() { public function testNotString() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/String')); $node->setType($this->graph->createNode('coid://json.co-n.net/String'));
@@ -38,10 +39,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Number')); $node->setType($this->graph->createNode('coid://json.co-n.net/Number'));
$this->schemaValidator->validateAgainstNode(3.5, $node); $this->schemaValidator->validateAgainstNode(3.5, $node);
$this->addToAssertionCount(1);
} }
public function testNotNumber() { public function testNotNumber() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Number')); $node->setType($this->graph->createNode('coid://json.co-n.net/Number'));
@@ -52,10 +54,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Integer')); $node->setType($this->graph->createNode('coid://json.co-n.net/Integer'));
$this->schemaValidator->validateAgainstNode(12, $node); $this->schemaValidator->validateAgainstNode(12, $node);
$this->addToAssertionCount(1);
} }
public function testNotInteger() { public function testNotInteger() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Integer')); $node->setType($this->graph->createNode('coid://json.co-n.net/Integer'));
@@ -66,10 +69,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Array')); $node->setType($this->graph->createNode('coid://json.co-n.net/Array'));
$this->schemaValidator->validateAgainstNode([ 1, 2, "foo" ], $node); $this->schemaValidator->validateAgainstNode([ 1, 2, "foo" ], $node);
$this->addToAssertionCount(1);
} }
public function testNotArray() { public function testNotArray() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Array')); $node->setType($this->graph->createNode('coid://json.co-n.net/Array'));
@@ -83,10 +87,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
'a' => 'A', 'a' => 'A',
'b' => 'B' 'b' => 'B'
], $node); ], $node);
$this->addToAssertionCount(1);
} }
public function testNotObject() { public function testNotObject() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$node = $this->graph->createNode(); $node = $this->graph->createNode();
$node->setType($this->graph->createNode('coid://json.co-n.net/Object')); $node->setType($this->graph->createNode('coid://json.co-n.net/Object'));
@@ -105,10 +110,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
'a' => 'A', 'a' => 'A',
'b' => 'B' 'b' => 'B'
], $node); ], $node);
$this->addToAssertionCount(1);
} }
public function testObjectWithPropertyTypeError() { public function testObjectWithPropertyTypeError() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$stringNode = $this->graph->createNode(); $stringNode = $this->graph->createNode();
$stringNode->setProperty('coid://json.co-n.net/hasKey', 'a'); $stringNode->setProperty('coid://json.co-n.net/hasKey', 'a');
@@ -136,10 +142,11 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
'a' => 'A', 'a' => 'A',
'b' => 'B' 'b' => 'B'
], $node); ], $node);
$this->addToAssertionCount(1);
} }
public function testObjectWithRequiredPropertyTypeError() { public function testObjectWithRequiredPropertyTypeError() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$stringNode = $this->graph->createNode(); $stringNode = $this->graph->createNode();
$stringNode->setProperty('coid://json.co-n.net/hasKey', 'a'); $stringNode->setProperty('coid://json.co-n.net/hasKey', 'a');
@@ -156,7 +163,7 @@ class SchemaValidatorTest extends \PHPUnit_Framework_TestCase {
} }
public function testObjectWithRequiredPropertyMissing() { public function testObjectWithRequiredPropertyMissing() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$stringNode = $this->graph->createNode(); $stringNode = $this->graph->createNode();
$stringNode->setProperty('coid://json.co-n.net/hasKey', 'a'); $stringNode->setProperty('coid://json.co-n.net/hasKey', 'a');

View File

@@ -10,7 +10,7 @@ use ML\IRI\IRI;
use GuzzleHttp\Client, GuzzleHttp\Handler\MockHandler, use GuzzleHttp\Client, GuzzleHttp\Handler\MockHandler,
GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response; GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response;
class NodeReaderMockTest extends \PHPUnit_Framework_TestCase { class NodeReaderMockTest extends \PHPUnit\Framework\TestCase {
private $retriever; private $retriever;
private $reader; private $reader;
@@ -27,7 +27,7 @@ class NodeReaderMockTest extends \PHPUnit_Framework_TestCase {
'{"@context":{"co":"coid:\/\/cloudobjects.io\/","rdf":"http:\/\/www.w3.org\/1999\/02\/22-rdf-syntax-ns#","agws":"coid:\/\/aauid.net\/","rdfs":"http:\/\/www.w3.org\/2000\/01\/rdf-schema#"},"@id":"coid:\/\/cloudobjects.io","@type":["agws:Service","co:Namespace"],"co:isAtRevision":"6-fbea0c90b2c5e5300e4039ed99be9b2d","co:isVisibleTo":{"@id":"co:Public"},"co:recommendsPrefix":"co","co:wasUpdatedAt":{"@type":"http:\/\/www.w3.org\/2001\/XMLSchema#dateTime","@value":"2017-01-16T17:29:22+00:00"},"rdfs:comment":"The CloudObjects namespace defines the essential objects.","rdfs:label":"CloudObjects"}')); '{"@context":{"co":"coid:\/\/cloudobjects.io\/","rdf":"http:\/\/www.w3.org\/1999\/02\/22-rdf-syntax-ns#","agws":"coid:\/\/aauid.net\/","rdfs":"http:\/\/www.w3.org\/2000\/01\/rdf-schema#"},"@id":"coid:\/\/cloudobjects.io","@type":["agws:Service","co:Namespace"],"co:isAtRevision":"6-fbea0c90b2c5e5300e4039ed99be9b2d","co:isVisibleTo":{"@id":"co:Public"},"co:recommendsPrefix":"co","co:wasUpdatedAt":{"@type":"http:\/\/www.w3.org\/2001\/XMLSchema#dateTime","@value":"2017-01-16T17:29:22+00:00"},"rdfs:comment":"The CloudObjects namespace defines the essential objects.","rdfs:label":"CloudObjects"}'));
} }
protected function setUp() { protected function setUp(): void {
$this->retriever = new ObjectRetriever; $this->retriever = new ObjectRetriever;
$this->reader = new NodeReader([ $this->reader = new NodeReader([
'prefixes' => [ 'prefixes' => [

View File

@@ -10,7 +10,7 @@ use ML\IRI\IRI;
use GuzzleHttp\Client, GuzzleHttp\Handler\MockHandler, use GuzzleHttp\Client, GuzzleHttp\Handler\MockHandler,
GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response; GuzzleHttp\HandlerStack, GuzzleHttp\Psr7\Response;
class ObjectRetrieverMockTest extends \PHPUnit_Framework_TestCase { class ObjectRetrieverMockTest extends \PHPUnit\Framework\TestCase {
private $retriever; private $retriever;
@@ -20,7 +20,7 @@ class ObjectRetrieverMockTest extends \PHPUnit_Framework_TestCase {
$this->retriever->setClient(new Client(['handler' => $handler])); $this->retriever->setClient(new Client(['handler' => $handler]));
} }
protected function setUp() { protected function setUp(): void {
$this->retriever = new ObjectRetriever; $this->retriever = new ObjectRetriever;
} }

View File

@@ -10,11 +10,11 @@ use InvalidArgumentException;
use ML\IRI\IRI; use ML\IRI\IRI;
use CloudObjects\SDK\ObjectRetriever; use CloudObjects\SDK\ObjectRetriever;
class SchemaValidatorPublicTest extends \PHPUnit_Framework_TestCase { class SchemaValidatorPublicTest extends \PHPUnit\Framework\TestCase {
private $schemaValidator; private $schemaValidator;
public function setUp() { protected function setUp(): void {
$this->schemaValidator = new SchemaValidator(new ObjectRetriever); $this->schemaValidator = new SchemaValidator(new ObjectRetriever);
} }
@@ -24,10 +24,11 @@ class SchemaValidatorPublicTest extends \PHPUnit_Framework_TestCase {
'region' => 'Hessen', 'region' => 'Hessen',
'country-name' => 'Germany' 'country-name' => 'Germany'
], new IRI('coid://json.co-n.net/Address')); ], new IRI('coid://json.co-n.net/Address'));
$this->addToAssertionCount(1);
} }
public function testNotAddress() { public function testNotAddress() {
$this->setExpectedException(InvalidArgumentException::class); $this->expectException(InvalidArgumentException::class);
$this->schemaValidator->validateAgainstCOID([ $this->schemaValidator->validateAgainstCOID([
'region' => 'Hessen', 'region' => 'Hessen',

View File

@@ -8,11 +8,11 @@ namespace CloudObjects\SDK;
use ML\IRI\IRI; use ML\IRI\IRI;
class ObjectRetrieverTest extends \PHPUnit_Framework_TestCase { class ObjectRetrieverPublicTest extends \PHPUnit\Framework\TestCase {
private $retriever; private $retriever;
protected function setUp() { protected function setUp(): void {
$this->retriever = new ObjectRetriever; $this->retriever = new ObjectRetriever;
} }