diff options
-rw-r--r-- | .github/workflows/oci.yml | 7 | ||||
-rw-r--r-- | tests/lib/Security/CredentialsManagerTest.php | 81 |
2 files changed, 3 insertions, 85 deletions
diff --git a/.github/workflows/oci.yml b/.github/workflows/oci.yml index 04d1dfdbab7..382ba4dafec 100644 --- a/.github/workflows/oci.yml +++ b/.github/workflows/oci.yml @@ -12,10 +12,9 @@ jobs: runs-on: ubuntu-20.04 strategy: - # do not stop on another job's failure fail-fast: false matrix: - php-versions: [ '7.4' ] + php-versions: [ '7.3', '7.4', '8.0' ] databases: [ 'oci' ] name: php${{ matrix.php-versions }}-${{ matrix.databases }} @@ -41,8 +40,8 @@ jobs: uses: shivammathur/setup-php@v2 with: php-version: ${{ matrix.php-versions }} - extensions: ctype,curl,dom,fileinfo,gd,iconv,intl,json,mbstring,oci8,openssl,pdo_sqlite,posix,sqlite,xml,zip - tools: phpunit:8.5.2 + extensions: ctype,curl,dom,fileinfo,gd,iconv,imagick,intl,json,mbstring,oci8,openssl,pdo_sqlite,posix,sqlite,xml,zip + tools: phpunit:9 coverage: none - name: Set up Nextcloud diff --git a/tests/lib/Security/CredentialsManagerTest.php b/tests/lib/Security/CredentialsManagerTest.php index 3335e18a8b1..f81db330640 100644 --- a/tests/lib/Security/CredentialsManagerTest.php +++ b/tests/lib/Security/CredentialsManagerTest.php @@ -24,92 +24,11 @@ declare(strict_types=1); namespace Test\Security; -use OC\Security\CredentialsManager; -use OCP\DB\IResult; -use OCP\DB\QueryBuilder\IExpressionBuilder; -use OCP\DB\QueryBuilder\IQueryBuilder; -use OCP\IDBConnection; -use OCP\Security\ICrypto; - /** * @group DB */ class CredentialsManagerTest extends \Test\TestCase { - /** @var ICrypto */ - protected $crypto; - - /** @var IDBConnection */ - protected $dbConnection; - - /** @var CredentialsManager */ - protected $manager; - - protected function setUp(): void { - parent::setUp(); - $this->crypto = $this->createMock(ICrypto::class); - $this->dbConnection = $this->getMockBuilder(IDBConnection::class) - ->disableOriginalConstructor() - ->getMock(); - $this->manager = new CredentialsManager($this->crypto, $this->dbConnection); - } - - private function getQueryResult($row) { - $result = $this->createMock(IResult::class); - - $result->expects($this->any()) - ->method('fetch') - ->willReturn($row); - - return $result; - } - - public function testStore() { - $userId = 'abc'; - $identifier = 'foo'; - $credentials = 'bar'; - - $this->crypto->expects($this->once()) - ->method('encrypt') - ->with(json_encode($credentials)) - ->willReturn('baz'); - - $this->dbConnection->expects($this->once()) - ->method('setValues') - ->with(CredentialsManager::DB_TABLE, - ['user' => $userId, 'identifier' => $identifier], - ['credentials' => 'baz'] - ); - - $this->manager->store($userId, $identifier, $credentials); - } - - public function testRetrieve() { - $userId = 'abc'; - $identifier = 'foo'; - - $this->crypto->expects($this->once()) - ->method('decrypt') - ->with('baz') - ->willReturn(json_encode('bar')); - - $eb = $this->createMock(IExpressionBuilder::class); - $qb = $this->createMock(IQueryBuilder::class); - $qb->method('select')->willReturnSelf(); - $qb->method('from')->willReturnSelf(); - $qb->method('where')->willReturnSelf(); - $qb->method('expr')->willReturn($eb); - $qb->expects($this->once()) - ->method('execute') - ->willReturn($this->getQueryResult(['credentials' => 'baz'])); - - $this->dbConnection->expects($this->once()) - ->method('getQueryBuilder') - ->willReturn($qb); - - $this->manager->retrieve($userId, $identifier); - } - /** * @dataProvider credentialsProvider */ |