mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2025-10-24 06:24:36 +00:00

* chore: remove redundant arguments * chore: remove unused constructor params * chore: reorganize constructors * chore: remove unnecessary awaits in returns * chore: remove unnecessary paranthesis * chore: add lints * chore: clean up after merge * chore: add sort constructors first * chore: organize constructors in blocs * chore: use sizedbox.shrink over empty container
82 lines
2.4 KiB
Dart
82 lines
2.4 KiB
Dart
import 'package:flowy_infra/colorscheme/colorscheme.dart';
|
|
import 'package:flowy_infra/plugins/service/location_service.dart';
|
|
import 'package:flowy_infra/plugins/service/models/flowy_dynamic_plugin.dart';
|
|
import 'package:flowy_infra/plugins/service/plugin_service.dart';
|
|
import 'package:flowy_infra/theme.dart';
|
|
import 'package:flutter/widgets.dart';
|
|
import 'package:flutter_test/flutter_test.dart';
|
|
|
|
class MockPluginService implements FlowyPluginService {
|
|
@override
|
|
Future<void> addPlugin(FlowyDynamicPlugin plugin) =>
|
|
throw UnimplementedError();
|
|
|
|
@override
|
|
Future<FlowyDynamicPlugin?> lookup({required String name}) =>
|
|
throw UnimplementedError();
|
|
|
|
@override
|
|
Future<DynamicPluginLibrary> get plugins async => const Iterable.empty();
|
|
|
|
@override
|
|
void setLocation(PluginLocationService locationService) =>
|
|
throw UnimplementedError();
|
|
}
|
|
|
|
void main() {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
group('AppTheme', () {
|
|
test('fallback theme', () {
|
|
const theme = AppTheme.fallback;
|
|
|
|
expect(theme.builtIn, true);
|
|
expect(theme.themeName, BuiltInTheme.defaultTheme);
|
|
expect(theme.lightTheme, isA<FlowyColorScheme>());
|
|
expect(theme.darkTheme, isA<FlowyColorScheme>());
|
|
});
|
|
|
|
test('built-in themes', () {
|
|
final themes = AppTheme.builtins;
|
|
|
|
expect(themes, isNotEmpty);
|
|
for (final theme in themes) {
|
|
expect(theme.builtIn, true);
|
|
expect(
|
|
theme.themeName,
|
|
anyOf([
|
|
BuiltInTheme.defaultTheme,
|
|
BuiltInTheme.dandelion,
|
|
BuiltInTheme.lavender,
|
|
BuiltInTheme.lemonade,
|
|
]),
|
|
);
|
|
expect(theme.lightTheme, isA<FlowyColorScheme>());
|
|
expect(theme.darkTheme, isA<FlowyColorScheme>());
|
|
}
|
|
});
|
|
|
|
test('fromName returns existing theme', () async {
|
|
final theme = await AppTheme.fromName(
|
|
BuiltInTheme.defaultTheme,
|
|
pluginService: MockPluginService(),
|
|
);
|
|
|
|
expect(theme, isNotNull);
|
|
expect(theme.builtIn, true);
|
|
expect(theme.themeName, BuiltInTheme.defaultTheme);
|
|
expect(theme.lightTheme, isA<FlowyColorScheme>());
|
|
expect(theme.darkTheme, isA<FlowyColorScheme>());
|
|
});
|
|
|
|
test('fromName throws error for non-existent theme', () async {
|
|
expect(
|
|
() async => AppTheme.fromName(
|
|
'bogus',
|
|
pluginService: MockPluginService(),
|
|
),
|
|
throwsArgumentError,
|
|
);
|
|
});
|
|
});
|
|
}
|