|
1 | | -// ignore_for_file: prefer_const_constructors |
| 1 | +import 'package:ht_kv_storage_service/ht_kv_storage_service.dart'; |
| 2 | +import 'package:mocktail/mocktail.dart'; |
2 | 3 | import 'package:test/test.dart'; |
3 | 4 |
|
4 | | -// Tests for KVStorageService implementations would go in separate packages |
5 | | -// specific to those implementations. |
6 | | -// This file can remain as a placeholder or be removed if no direct tests |
7 | | -// for the abstract class itself are planned. |
| 5 | +// Create a mock implementation of the abstract class |
| 6 | +class MockHtKVStorageService extends Mock implements HtKVStorageService {} |
| 7 | + |
8 | 8 | void main() { |
9 | | - group('KVStorageService', () { |
10 | | - // No direct tests for the abstract class itself. |
11 | | - // Concrete implementations should be tested. |
| 9 | + group('HtKVStorageService Abstract Class', () { |
| 10 | + late MockHtKVStorageService mockStorageService; |
| 11 | + |
| 12 | + setUp(() { |
| 13 | + mockStorageService = MockHtKVStorageService(); |
| 14 | + |
| 15 | + // Register fallback values for methods returning non-nullable types |
| 16 | + // or futures of non-nullable types, if needed by specific tests. |
| 17 | + // For basic coverage, stubbing might be sufficient. |
| 18 | + registerFallbackValue(''); // For String key |
| 19 | + registerFallbackValue(false); // For bool value/defaultValue |
| 20 | + registerFallbackValue(0); // For int value |
| 21 | + registerFallbackValue(0.0); // For double value |
| 22 | + |
| 23 | + // Stubbing the methods to return default futures/values |
| 24 | + // This ensures the methods can be called without null errors |
| 25 | + // and contributes to coverage. |
| 26 | + when( |
| 27 | + () => mockStorageService.writeString( |
| 28 | + key: any(named: 'key'), |
| 29 | + value: any(named: 'value'), |
| 30 | + ), |
| 31 | + ).thenAnswer((_) async {}); |
| 32 | + when(() => mockStorageService.readString(key: any(named: 'key'))) |
| 33 | + .thenAnswer((_) async => null); |
| 34 | + when( |
| 35 | + () => mockStorageService.writeBool( |
| 36 | + key: any(named: 'key'), |
| 37 | + value: any(named: 'value'), |
| 38 | + ), |
| 39 | + ).thenAnswer((_) async {}); |
| 40 | + when( |
| 41 | + () => mockStorageService.readBool( |
| 42 | + key: any(named: 'key'), |
| 43 | + defaultValue: any(named: 'defaultValue'), |
| 44 | + ), |
| 45 | + ).thenAnswer((_) async => false); // Return default |
| 46 | + when( |
| 47 | + () => mockStorageService.readBool( |
| 48 | + key: any(named: 'key'), |
| 49 | + ), |
| 50 | + ) // Handle call without defaultValue |
| 51 | + .thenAnswer((_) async => false); |
| 52 | + when( |
| 53 | + () => mockStorageService.writeInt( |
| 54 | + key: any(named: 'key'), |
| 55 | + value: any(named: 'value'), |
| 56 | + ), |
| 57 | + ).thenAnswer((_) async {}); |
| 58 | + when(() => mockStorageService.readInt(key: any(named: 'key'))) |
| 59 | + .thenAnswer((_) async => null); |
| 60 | + when( |
| 61 | + () => mockStorageService.writeDouble( |
| 62 | + key: any(named: 'key'), |
| 63 | + value: any(named: 'value'), |
| 64 | + ), |
| 65 | + ).thenAnswer((_) async {}); |
| 66 | + when(() => mockStorageService.readDouble(key: any(named: 'key'))) |
| 67 | + .thenAnswer((_) async => null); |
| 68 | + when(() => mockStorageService.delete(key: any(named: 'key'))) |
| 69 | + .thenAnswer((_) async {}); |
| 70 | + when(() => mockStorageService.clearAll()).thenAnswer((_) async {}); |
| 71 | + }); |
| 72 | + |
| 73 | + // Test calling each method to ensure coverage of the abstract definition |
| 74 | + test('writeString can be called', () async { |
| 75 | + await mockStorageService.writeString(key: 'testKey', value: 'testValue'); |
| 76 | + verify( |
| 77 | + () => mockStorageService.writeString( |
| 78 | + key: 'testKey', |
| 79 | + value: 'testValue', |
| 80 | + ), |
| 81 | + ).called(1); |
| 82 | + }); |
| 83 | + |
| 84 | + test('readString can be called', () async { |
| 85 | + await mockStorageService.readString(key: 'testKey'); |
| 86 | + verify(() => mockStorageService.readString(key: 'testKey')).called(1); |
| 87 | + }); |
| 88 | + |
| 89 | + test('writeBool can be called', () async { |
| 90 | + await mockStorageService.writeBool(key: 'testKey', value: true); |
| 91 | + verify(() => mockStorageService.writeBool(key: 'testKey', value: true)) |
| 92 | + .called(1); |
| 93 | + }); |
| 94 | + |
| 95 | + test('readBool can be called with default', () async { |
| 96 | + await mockStorageService.readBool(key: 'testKey', defaultValue: true); |
| 97 | + verify( |
| 98 | + () => mockStorageService.readBool(key: 'testKey', defaultValue: true), |
| 99 | + ).called(1); |
| 100 | + }); |
| 101 | + |
| 102 | + test('readBool can be called without default', () async { |
| 103 | + await mockStorageService.readBool(key: 'testKey'); |
| 104 | + verify(() => mockStorageService.readBool(key: 'testKey')).called(1); |
| 105 | + }); |
| 106 | + |
| 107 | + test('writeInt can be called', () async { |
| 108 | + await mockStorageService.writeInt(key: 'testKey', value: 123); |
| 109 | + verify(() => mockStorageService.writeInt(key: 'testKey', value: 123)) |
| 110 | + .called(1); |
| 111 | + }); |
| 112 | + |
| 113 | + test('readInt can be called', () async { |
| 114 | + await mockStorageService.readInt(key: 'testKey'); |
| 115 | + verify(() => mockStorageService.readInt(key: 'testKey')).called(1); |
| 116 | + }); |
| 117 | + |
| 118 | + test('writeDouble can be called', () async { |
| 119 | + await mockStorageService.writeDouble(key: 'testKey', value: 1.23); |
| 120 | + verify(() => mockStorageService.writeDouble(key: 'testKey', value: 1.23)) |
| 121 | + .called(1); |
| 122 | + }); |
| 123 | + |
| 124 | + test('readDouble can be called', () async { |
| 125 | + await mockStorageService.readDouble(key: 'testKey'); |
| 126 | + verify(() => mockStorageService.readDouble(key: 'testKey')).called(1); |
| 127 | + }); |
| 128 | + |
| 129 | + test('delete can be called', () async { |
| 130 | + await mockStorageService.delete(key: 'testKey'); |
| 131 | + verify(() => mockStorageService.delete(key: 'testKey')).called(1); |
| 132 | + }); |
| 133 | + |
| 134 | + test('clearAll can be called', () async { |
| 135 | + await mockStorageService.clearAll(); |
| 136 | + verify(() => mockStorageService.clearAll()).called(1); |
| 137 | + }); |
12 | 138 | }); |
13 | 139 | } |
0 commit comments