|
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133 |
- import test from 'ava';
- import {LocalStorageMock} from './_helpers';
- import Auth from '../src/api/auth';
- import Storage, {LOCAL_STORAGE_KEY} from '../src/api/storage';
- import nock from 'nock';
-
-
- function AuthFactory(token, localStorage = new LocalStorageMock()) {
- const storage = new Storage(localStorage);
- storage.saveToken(token);
- return new Auth(storage);
- }
-
- test('request token', t => {
- const token = '5e0651';
- const user = {email: 'test@example.org', password: 'password'};
- nock('https://lesspass.com').post('/api/tokens/auth/', user).reply(201, {token});
- return Auth._requestToken(user, {baseURL: 'https://lesspass.com'}).then(requestedToken => {
- t.is(requestedToken, token);
- });
- });
-
- test('request new token', t => {
- const token = '3e3231';
- const newToken = 'wibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9eyJzdWIiOiIxMjM0NTY3ODkwIi';
- nock('https://lesspass.com').post('/api/tokens/refresh/', {token}).reply(200, {token: newToken});
- return Auth._requestNewToken({token}, {baseURL: 'https://lesspass.com'}).then(refreshedToken => {
- t.is(refreshedToken, newToken);
- });
- });
-
- test('user first connection is guest', t => {
- const storage = new Storage(new LocalStorageMock());
- const auth = new Auth(storage);
- t.true(auth.isGuest());
- });
-
- test('user return on site before token expire', t => {
- const auth = AuthFactory('eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJmb28iOiJiYXIiLCJpYXQiOjE0MzcwMTg1ODIsImV4cCI6MTc1NzkyODQzNH0.KzEBhVgm3xa51jsBklB0Ib9DDwAkvynOnkwLLJoD5AU');
- t.true(auth.isAuthenticated());
- t.false(auth.isGuest());
- });
-
- test('user return on site after token expiration', t => {
- const auth = AuthFactory('eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJmb28iOiJiYXIiLCJpYXQiOjE0MzcwMTg1ODIsImV4cCI6MTQzNzAxODU4M30.NmMv7sXjM1dW0eALNXud8LoXknZ0mH14GtnFclwJv0s');
- t.false(auth.isAuthenticated());
- t.true(auth.isGuest());
- t.false(auth.user.authenticated);
- });
-
- test('login save token', t => {
- const token = '3e3231';
- const storage = new LocalStorageMock();
- const auth = AuthFactory(token, storage);
- const user = {
- email: 'test@lesspass.com',
- password: 'password'
- };
- nock('https://lesspass.com').post('/api/tokens/auth/', user).reply(201, {token});
- return auth.login(user).then(() => {
- t.is(JSON.parse(storage.getItem(LOCAL_STORAGE_KEY)).jwt, token);
- });
- });
-
- test('logout user remove token and unauthenticate user', t => {
- const token = '3e3231';
- const storage = new LocalStorageMock();
- const auth = AuthFactory(token, storage);
- return auth.logout().then(() => {
- t.falsy(storage.getItem(LOCAL_STORAGE_KEY));
- });
- });
-
- test('login custom endpoint', t => {
- const token = '3e3231';
- const storage = new LocalStorageMock();
- const auth = AuthFactory(token, storage);
- const user = {
- email: 'test@lesspass.com',
- password: 'password'
- };
- nock('https://test.example.org').post('/api/tokens/auth/', user).reply(201, {token});
- return auth.login(user, 'https://test.example.org').then(() => {
- t.is(JSON.parse(storage.getItem(LOCAL_STORAGE_KEY)).jwt, token);
- });
- });
-
- test('refresh token', t => {
- const token = '3e3231';
- const storage = new LocalStorageMock();
- const auth = AuthFactory(token, storage);
- const newToken = 'wibmFtZSI6IkpvaG4gRG9lIiwiYWRtaW4iOnRydWV9eyJzdWIiOiIxMjM0NTY3ODkwIi';
- nock('https://lesspass.com').post('/api/tokens/refresh/', {token}).reply(200, {token: newToken});
- return auth.refreshToken().then(() => {
- t.is(JSON.parse(storage.getItem(LOCAL_STORAGE_KEY)).jwt, newToken);
- });
- });
-
- test('should register a user', t => {
- const user = {
- email: 'test@lesspass.com',
- password: 'password'
- };
- const localStorage = new LocalStorageMock();
- const storage = new Storage(localStorage);
- const auth = new Auth(storage);
- nock('https://lesspass.com').post('/api/auth/register/', user).reply(201, {email: user.email, pk: 1});
- return auth.register(user).then(newUser => {
- t.is(newUser.email, user.email);
- });
- });
-
- test('should reset a password', t => {
- var email = 'test@lesspass.com';
- const localStorage = new LocalStorageMock();
- const storage = new Storage(localStorage);
- const auth = new Auth(storage);
- nock('https://lesspass.com').post('/api/auth/password/reset/', {email}).reply(204);
- t.notThrows(auth.resetPassword({email}));
- });
-
- test('should confirm reset password', t => {
- var newPassword ={
- uid: 'MQ',
- token: '5g1-2bd69bd6f6dcd73f8124',
- new_password: 'password1'
- };
- const localStorage = new LocalStorageMock();
- const storage = new Storage(localStorage);
- const auth = new Auth(storage);
- nock('https://lesspass.com').post('/api/auth/password/reset/confirm/', newPassword).reply(204);
- t.notThrows(auth.confirmResetPassword(newPassword));
- });
|