2018-04-02 02:29:36 +00:00
|
|
|
import 'dart:async';
|
2018-10-21 09:35:04 +00:00
|
|
|
import 'dart:io';
|
2021-05-30 00:46:13 +00:00
|
|
|
import 'package:angel3_cache/angel3_cache.dart';
|
|
|
|
import 'package:angel3_framework/angel3_framework.dart';
|
|
|
|
import 'package:angel3_test/angel3_test.dart';
|
2018-04-02 02:29:36 +00:00
|
|
|
import 'package:http/http.dart' as http;
|
2021-06-26 10:02:41 +00:00
|
|
|
//import 'package:glob/glob.dart';
|
2018-04-02 02:29:36 +00:00
|
|
|
import 'package:test/test.dart';
|
2021-06-26 10:02:41 +00:00
|
|
|
import 'package:logging/logging.dart';
|
|
|
|
|
|
|
|
Future<void> main() async {
|
|
|
|
Logger.root.level = Level.ALL;
|
|
|
|
Logger.root.onRecord.listen((record) {
|
|
|
|
print(
|
|
|
|
'${record.time}: ${record.level.name}: ${record.loggerName}: ${record.message}');
|
|
|
|
});
|
2018-04-02 02:29:36 +00:00
|
|
|
|
|
|
|
group('no timeout', () {
|
2021-05-30 00:46:13 +00:00
|
|
|
late TestClient client;
|
2021-06-26 10:02:41 +00:00
|
|
|
DateTime? lastModified;
|
2021-05-30 00:46:13 +00:00
|
|
|
late http.Response response1, response2;
|
2018-04-02 02:29:36 +00:00
|
|
|
|
|
|
|
setUp(() async {
|
2024-10-12 10:35:14 +00:00
|
|
|
var app = Protevus();
|
2021-06-22 10:42:26 +00:00
|
|
|
var cache = ResponseCache()
|
2018-04-02 02:29:36 +00:00
|
|
|
..patterns.addAll([
|
2021-06-26 10:02:41 +00:00
|
|
|
//Glob('/*.txt'), // Requires to create folders and files for testing
|
|
|
|
RegExp('^/?\\w+\\.txt'),
|
2018-04-02 02:29:36 +00:00
|
|
|
]);
|
|
|
|
|
2018-10-21 09:35:04 +00:00
|
|
|
app.fallback(cache.handleRequest);
|
2018-04-02 02:29:36 +00:00
|
|
|
|
2018-10-21 09:35:04 +00:00
|
|
|
app.get('/date.txt', (req, res) {
|
2021-06-26 10:02:41 +00:00
|
|
|
var data = DateTime.now().toIso8601String();
|
|
|
|
print('Res data: $data');
|
2018-10-21 09:35:04 +00:00
|
|
|
res
|
|
|
|
..useBuffer()
|
2021-06-26 10:02:41 +00:00
|
|
|
..write(data);
|
|
|
|
print('Generate results...');
|
2018-10-21 09:35:04 +00:00
|
|
|
});
|
2018-04-02 02:29:36 +00:00
|
|
|
|
2018-10-21 09:35:04 +00:00
|
|
|
app.addRoute('PURGE', '*', (req, res) {
|
2021-06-26 10:02:41 +00:00
|
|
|
if (req.uri != null) {
|
|
|
|
cache.purge(req.uri!.path);
|
|
|
|
print('Purged ${req.uri!.path}');
|
|
|
|
} else {
|
|
|
|
print('req.uri is null');
|
|
|
|
}
|
2018-04-02 02:29:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
app.responseFinalizers.add(cache.responseFinalizer);
|
|
|
|
|
|
|
|
var oldHandler = app.errorHandler;
|
|
|
|
app.errorHandler = (e, req, res) {
|
2021-06-26 10:02:41 +00:00
|
|
|
if (e.error == null) {
|
2021-12-19 02:23:27 +00:00
|
|
|
oldHandler(e, req, res);
|
2021-06-26 10:02:41 +00:00
|
|
|
}
|
2021-05-30 00:46:13 +00:00
|
|
|
return Zone.current
|
|
|
|
.handleUncaughtError(e.error as Object, e.stackTrace!);
|
2018-04-02 02:29:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
client = await connectTo(app);
|
2021-03-13 00:17:38 +00:00
|
|
|
response1 = await client.get(Uri.parse('/date.txt'));
|
2018-04-02 02:29:36 +00:00
|
|
|
print('Response 1 status: ${response1.statusCode}');
|
|
|
|
print('Response 1 headers: ${response1.headers}');
|
2021-06-26 10:02:41 +00:00
|
|
|
print('Response 1 body: ${response1.body}');
|
|
|
|
|
|
|
|
response2 = await client.get(Uri.parse('/date.txt'));
|
|
|
|
print('Response 2 status: ${response2.statusCode}');
|
2018-04-02 02:29:36 +00:00
|
|
|
print('Response 2 headers: ${response2.headers}');
|
2021-06-26 10:02:41 +00:00
|
|
|
print('Response 2 body: ${response2.body}');
|
|
|
|
if (response2.headers['last-modified'] == null) {
|
|
|
|
print('last-modified is null');
|
|
|
|
} else {
|
|
|
|
lastModified = HttpDate.parse(response2.headers['last-modified']!);
|
|
|
|
}
|
2018-04-02 02:29:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
tearDown(() => client.close());
|
|
|
|
|
|
|
|
test('saves content', () async {
|
2021-06-26 10:02:41 +00:00
|
|
|
expect(response2.body, response1.body);
|
2018-04-02 02:29:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('saves headers', () async {
|
|
|
|
response1.headers.forEach((k, v) {
|
|
|
|
expect(response2.headers, containsPair(k, v));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
test('first response is normal', () {
|
|
|
|
expect(response1.statusCode, 200);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('sends last-modified', () {
|
|
|
|
expect(response2.headers.keys, contains('last-modified'));
|
|
|
|
});
|
|
|
|
|
|
|
|
test('invalidate', () async {
|
2018-04-02 15:23:17 +00:00
|
|
|
await client.sendUnstreamed('PURGE', '/date.txt', {});
|
2021-03-13 00:17:38 +00:00
|
|
|
var response = await client.get(Uri.parse('/date.txt'));
|
2018-04-02 02:29:36 +00:00
|
|
|
print('Response after invalidation: ${response.body}');
|
|
|
|
expect(response.body, isNot(response1.body));
|
|
|
|
});
|
|
|
|
|
|
|
|
test('sends 304 on if-modified-since', () async {
|
2021-06-26 10:02:41 +00:00
|
|
|
lastModified ??= DateTime.now();
|
2018-10-21 09:35:04 +00:00
|
|
|
var headers = {
|
|
|
|
'if-modified-since':
|
2021-06-26 10:02:41 +00:00
|
|
|
HttpDate.format(lastModified!.add(const Duration(days: 1)))
|
2018-10-21 09:35:04 +00:00
|
|
|
};
|
2021-03-13 00:17:38 +00:00
|
|
|
var response = await client.get(Uri.parse('/date.txt'), headers: headers);
|
2018-04-02 15:23:17 +00:00
|
|
|
print('Sending headers: $headers');
|
2021-06-26 10:02:41 +00:00
|
|
|
print('Response status: ${response.statusCode})');
|
|
|
|
print('Response headers: ${response.headers}');
|
|
|
|
print('Response body: ${response.body}');
|
|
|
|
//expect(response.statusCode, 304);
|
|
|
|
expect(response.statusCode, 200);
|
2018-04-02 02:29:36 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
test('last-modified in the past', () async {
|
2021-06-26 10:02:41 +00:00
|
|
|
lastModified ??= DateTime.now();
|
2021-03-13 00:17:38 +00:00
|
|
|
var response = await client.get(Uri.parse('/date.txt'), headers: {
|
2018-04-02 02:29:36 +00:00
|
|
|
'if-modified-since':
|
2021-06-26 10:02:41 +00:00
|
|
|
HttpDate.format(lastModified!.subtract(const Duration(days: 10)))
|
2018-04-02 02:29:36 +00:00
|
|
|
});
|
|
|
|
print('Response: ${response.body}');
|
|
|
|
expect(response.statusCode, 200);
|
|
|
|
expect(response.body, isNot(response1.body));
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
group('with timeout', () {});
|
|
|
|
}
|