| library shelf_static.basic_file_test; |
| |
| import 'dart:io'; |
| import 'package:http_parser/http_parser.dart'; |
| import 'package:path/path.dart' as p; |
| import 'package:scheduled_test/descriptor.dart' as d; |
| import 'package:scheduled_test/scheduled_test.dart'; |
| |
| import 'package:shelf_static/shelf_static.dart'; |
| import 'test_util.dart'; |
| |
| void main() { |
| setUp(() { |
| var tempDir; |
| schedule(() { |
| return Directory.systemTemp.createTemp('shelf_static-test-').then((dir) { |
| tempDir = dir; |
| d.defaultRoot = tempDir.path; |
| }); |
| }); |
| |
| d.file('index.html', '<html></html>').create(); |
| d.file('root.txt', 'root txt').create(); |
| d.file('random.unknown', 'no clue').create(); |
| d |
| .dir('files', [ |
| d.file('test.txt', 'test txt content'), |
| d.file('with space.txt', 'with space content') |
| ]) |
| .create(); |
| |
| currentSchedule.onComplete.schedule(() { |
| d.defaultRoot = null; |
| return tempDir.delete(recursive: true); |
| }); |
| }); |
| |
| test('access root file', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/root.txt').then((response) { |
| expect(response.statusCode, HttpStatus.OK); |
| expect(response.contentLength, 8); |
| expect(response.readAsString(), completion('root txt')); |
| }); |
| }); |
| }); |
| |
| test('access root file with space', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/files/with%20space.txt').then((response) { |
| expect(response.statusCode, HttpStatus.OK); |
| expect(response.contentLength, 18); |
| expect(response.readAsString(), completion('with space content')); |
| }); |
| }); |
| }); |
| |
| test('access root file with unencoded space', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/files/with%20space.txt').then((response) { |
| expect(response.statusCode, HttpStatus.OK); |
| expect(response.contentLength, 18); |
| expect(response.readAsString(), completion('with space content')); |
| }); |
| }); |
| }); |
| |
| test('access file under directory', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/files/test.txt').then((response) { |
| expect(response.statusCode, HttpStatus.OK); |
| expect(response.contentLength, 16); |
| expect(response.readAsString(), completion('test txt content')); |
| }); |
| }); |
| }); |
| |
| test('file not found', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/not_here.txt').then((response) { |
| expect(response.statusCode, HttpStatus.NOT_FOUND); |
| }); |
| }); |
| }); |
| |
| test('last modified', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| var rootPath = p.join(d.defaultRoot, 'root.txt'); |
| var modified = new File(rootPath).statSync().changed.toUtc(); |
| |
| return makeRequest(handler, '/root.txt').then((response) { |
| expect(response.lastModified, atSameTimeToSecond(modified)); |
| }); |
| }); |
| }); |
| |
| group('if modified since', () { |
| test('same as last modified', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| var rootPath = p.join(d.defaultRoot, 'root.txt'); |
| var modified = new File(rootPath).statSync().changed.toUtc(); |
| |
| var headers = {HttpHeaders.IF_MODIFIED_SINCE: formatHttpDate(modified)}; |
| |
| return makeRequest(handler, '/root.txt', headers: headers).then( |
| (response) { |
| expect(response.statusCode, HttpStatus.NOT_MODIFIED); |
| expect(response.contentLength, isNull); |
| }); |
| }); |
| }); |
| |
| test('before last modified', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| var rootPath = p.join(d.defaultRoot, 'root.txt'); |
| var modified = new File(rootPath).statSync().changed.toUtc(); |
| |
| var headers = { |
| HttpHeaders.IF_MODIFIED_SINCE: |
| formatHttpDate(modified.subtract(const Duration(seconds: 1))) |
| }; |
| |
| return makeRequest(handler, '/root.txt', headers: headers).then( |
| (response) { |
| expect(response.statusCode, HttpStatus.OK); |
| expect(response.lastModified, atSameTimeToSecond(modified)); |
| }); |
| }); |
| }); |
| |
| test('after last modified', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| var rootPath = p.join(d.defaultRoot, 'root.txt'); |
| var modified = new File(rootPath).statSync().changed.toUtc(); |
| |
| var headers = { |
| HttpHeaders.IF_MODIFIED_SINCE: |
| formatHttpDate(modified.add(const Duration(seconds: 1))) |
| }; |
| |
| return makeRequest(handler, '/root.txt', headers: headers).then( |
| (response) { |
| expect(response.statusCode, HttpStatus.NOT_MODIFIED); |
| expect(response.contentLength, isNull); |
| }); |
| }); |
| }); |
| }); |
| |
| group('content type', () { |
| test('root.txt should be text/plain', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/root.txt').then((response) { |
| expect(response.mimeType, 'text/plain'); |
| }); |
| }); |
| }); |
| |
| test('index.html should be text/html', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/index.html').then((response) { |
| expect(response.mimeType, 'text/html'); |
| }); |
| }); |
| }); |
| |
| test('random.unknown should be null', () { |
| schedule(() { |
| var handler = createStaticHandler(d.defaultRoot); |
| |
| return makeRequest(handler, '/random.unknown').then((response) { |
| expect(response.mimeType, isNull); |
| }); |
| }); |
| }); |
| }); |
| } |