Пример #1
0
    def test_user_not_found(self):
        """Response when user doesn't exists."""
        data = provider.deviceData('usernotfound')
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)

        data = {
            'method' : 'password',
            'token' : data['continuationToken'],
            'password' : 'password'
        }
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 401
Пример #2
0
    def test_bad_continuation_token(self):
        """Response when token is bad."""
        password = provider.func_name() + 'password'
        user = provider.user(password)

        data = provider.deviceData(user.username)
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)

        data = {
            'method' : 'password',
            'token' : data['continuationToken'] + 'plop',
            'password' : password
        }
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 403
Пример #3
0
    def test_retrieve(self):
        """Access token retrieving workflow, without error."""

        password = provider.func_name() + 'password'
        user = provider.user(password)

        data = provider.deviceData(user.username)
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)
        self._assert_access_token_step1_response(data)

        data = {
            'method' : 'password',
            'token' : data['continuationToken'],
            'password' : password
        }
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 201

        responseData = json.loads(response.data)
        assert 'accessToken' in responseData
        accessToken = responseData['accessToken']
        # does it creates a device
        assert pyjmap.database.Device.query.filter_by(userId=user.id).count() == 1

        # check it doesn't create a new device at each connection
        response = self.client.post('/access-token', data=json.dumps(data), content_type='application/json')
        assert response.status_code == 201
        assert pyjmap.database.Device.query.filter_by(userId=user.id).count() == 1

        response = self.client.get('/endpoints', headers={'Authorization': accessToken})
        assert response.status_code == 200

        response = self.client.post('/', headers={'Authorization': accessToken}, data='[]', content_type='application/json')
        assert response.status_code == 200

        response = self.client.delete('/access-token', headers={'Authorization': accessToken})
        assert response.status_code == 204

        response = self.client.get('/endpoints', headers={'Authorization': accessToken})
        assert response.status_code == 401

        response = self.client.post('/', headers={'Authorization': accessToken}, data='[]')
        assert response.status_code == 401
Пример #4
0
    def test_user_not_found(self):
        """Response when user doesn't exists."""
        data = provider.deviceData('usernotfound')
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)

        data = {
            'method': 'password',
            'token': data['continuationToken'],
            'password': '******'
        }
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 401
Пример #5
0
    def test_expired_continuation_token(self):
        """Response when continuation token is expired."""
        password = provider.func_name() + 'password'
        user = provider.user(password)

        data = provider.deviceData(user.username)
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)

        data = {
            'method': 'password',
            'token': data['continuationToken'] + 'plop',
            'password': password
        }
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 403
Пример #6
0
    def test_retrieve(self):
        """Access token retrieving workflow, without error."""

        password = provider.func_name() + 'password'
        user = provider.user(password)

        data = provider.deviceData(user.username)
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 200
        data = json.loads(response.data)
        self._assert_access_token_step1_response(data)

        data = {
            'method': 'password',
            'token': data['continuationToken'],
            'password': password
        }
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 201

        responseData = json.loads(response.data)
        assert 'accessToken' in responseData
        accessToken = responseData['accessToken']
        # does it creates a device
        assert pyjmap.database.Device.query.filter_by(
            userId=user.id).count() == 1

        # check it doesn't create a new device at each connection
        response = self.client.post('/access-token',
                                    data=json.dumps(data),
                                    content_type='application/json')
        assert response.status_code == 201
        assert pyjmap.database.Device.query.filter_by(
            userId=user.id).count() == 1

        response = self.client.get('/endpoints',
                                   headers={'Authorization': accessToken})
        assert response.status_code == 200

        response = self.client.post('/',
                                    headers={'Authorization': accessToken},
                                    data='[]',
                                    content_type='application/json')
        assert response.status_code == 200

        response = self.client.delete('/access-token',
                                      headers={'Authorization': accessToken})
        assert response.status_code == 204

        response = self.client.get('/endpoints',
                                   headers={'Authorization': accessToken})
        assert response.status_code == 401

        response = self.client.post('/',
                                    headers={'Authorization': accessToken},
                                    data='[]')
        assert response.status_code == 401