jws = Mockery::mock('Namshi\JOSE\JWS'); $this->provider = new NamshiAdapter('secret', 'HS256', $this->jws); } public function tearDown() { Mockery::close(); } /** @test */ public function it_should_return_the_token_when_passing_a_valid_subject_to_encode() { $payload = ['sub' => 1, 'exp' => time(), 'iat' => time(), 'iss' => '/foo']; $this->jws->shouldReceive('setPayload')->once()->with($payload)->andReturn(Mockery::self()); $this->jws->shouldReceive('sign')->once()->with('secret')->andReturn(Mockery::self()); $this->jws->shouldReceive('getTokenString')->once()->andReturn('foo.bar.baz'); $token = $this->provider->encode($payload); $this->assertEquals('foo.bar.baz', $token); } /** @test */ public function it_should_throw_an_invalid_exception_when_the_payload_could_not_be_encoded() { $this->setExpectedException('Tymon\JWTAuth\Exceptions\JWTException'); $this->jws->shouldReceive('sign')->andThrow(new \Exception); $payload = ['sub' => 1, 'exp' => time(), 'iat' => time(), 'iss' => '/foo']; $token = $this->provider->encode($payload); } /** @test */ // public function it_should_return_the_payload_when_passing_a_valid_token_to_decode() // { // $this->jws->shouldReceive('load')->once()->with('foo.bar.baz')->andReturn(true); // $this->jws->shouldReceive('verify')->andReturn(true); // $payload = $this->provider->decode('foo.bar.baz'); // } /** @test */ public function it_should_throw_a_token_invalid_exception_when_the_token_could_not_be_decoded() { $this->setExpectedException('Tymon\JWTAuth\Exceptions\TokenInvalidException'); $this->jws->shouldReceive('verify')->andReturn(false); $token = $this->provider->decode('foo'); } }