forked from baron/baron-sso
121 lines
3.1 KiB
Dart
121 lines
3.1 KiB
Dart
import 'package:flutter_test/flutter_test.dart';
|
|
import 'package:userfront/core/services/logout_service.dart';
|
|
|
|
void main() {
|
|
test('현재 세션이 있으면 서버 세션 종료 후 로컬 로그아웃을 진행한다', () async {
|
|
final events = <String>[];
|
|
final service = LogoutService(
|
|
loadCurrentSessionId: () async {
|
|
events.add('load');
|
|
return 'current-sid';
|
|
},
|
|
revokeSession: (sessionId) async {
|
|
events.add('revoke:$sessionId');
|
|
},
|
|
clearAuth: () {
|
|
events.add('clear');
|
|
},
|
|
notifyAuthChanged: () {
|
|
events.add('notify');
|
|
},
|
|
);
|
|
|
|
await service.logout();
|
|
|
|
expect(events, ['load', 'revoke:current-sid', 'clear', 'notify']);
|
|
});
|
|
|
|
test('현재 세션이 없으면 서버 세션 종료 없이 로컬 로그아웃만 진행한다', () async {
|
|
final events = <String>[];
|
|
final service = LogoutService(
|
|
loadCurrentSessionId: () async {
|
|
events.add('load');
|
|
return null;
|
|
},
|
|
revokeSession: (sessionId) async {
|
|
events.add('revoke:$sessionId');
|
|
},
|
|
clearAuth: () {
|
|
events.add('clear');
|
|
},
|
|
notifyAuthChanged: () {
|
|
events.add('notify');
|
|
},
|
|
);
|
|
|
|
await service.logout();
|
|
|
|
expect(events, ['load', 'clear', 'notify']);
|
|
});
|
|
|
|
test('현재 세션 ID가 빈 문자열이면 서버 세션 종료 없이 로컬 로그아웃만 진행한다', () async {
|
|
final events = <String>[];
|
|
final service = LogoutService(
|
|
loadCurrentSessionId: () async {
|
|
events.add('load');
|
|
return '';
|
|
},
|
|
revokeSession: (sessionId) async {
|
|
events.add('revoke:$sessionId');
|
|
},
|
|
clearAuth: () {
|
|
events.add('clear');
|
|
},
|
|
notifyAuthChanged: () {
|
|
events.add('notify');
|
|
},
|
|
);
|
|
|
|
await service.logout();
|
|
|
|
expect(events, ['load', 'clear', 'notify']);
|
|
});
|
|
|
|
test('현재 세션 조회가 실패해도 로컬 로그아웃은 계속 진행한다', () async {
|
|
final events = <String>[];
|
|
final service = LogoutService(
|
|
loadCurrentSessionId: () async {
|
|
events.add('load');
|
|
throw Exception('load failed');
|
|
},
|
|
revokeSession: (sessionId) async {
|
|
events.add('revoke:$sessionId');
|
|
},
|
|
clearAuth: () {
|
|
events.add('clear');
|
|
},
|
|
notifyAuthChanged: () {
|
|
events.add('notify');
|
|
},
|
|
);
|
|
|
|
await service.logout();
|
|
|
|
expect(events, ['load', 'clear', 'notify']);
|
|
});
|
|
|
|
test('서버 세션 종료가 실패해도 로컬 로그아웃은 계속 진행한다', () async {
|
|
final events = <String>[];
|
|
final service = LogoutService(
|
|
loadCurrentSessionId: () async {
|
|
events.add('load');
|
|
return 'current-sid';
|
|
},
|
|
revokeSession: (sessionId) async {
|
|
events.add('revoke:$sessionId');
|
|
throw Exception('revoke failed');
|
|
},
|
|
clearAuth: () {
|
|
events.add('clear');
|
|
},
|
|
notifyAuthChanged: () {
|
|
events.add('notify');
|
|
},
|
|
);
|
|
|
|
await service.logout();
|
|
|
|
expect(events, ['load', 'revoke:current-sid', 'clear', 'notify']);
|
|
});
|
|
}
|