fade_in_image_test.dart 3.52 KB
Newer Older
1 2 3 4 5 6 7 8 9
// Copyright 2017 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

import 'dart:async';
import 'dart:ui' as ui;

import 'package:flutter/widgets.dart';
import 'package:flutter_test/flutter_test.dart';
10
import '../painting/image_test_utils.dart';
11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36

Future<Null> main() async {
  // These must run outside test zone to complete
  final ui.Image targetImage = await createTestImage();
  final ui.Image placeholderImage = await createTestImage();

  group('FadeInImage', () {
    testWidgets('animates uncached image and shows cached image immediately', (WidgetTester tester) async {
      // State type is private, hence using dynamic.
      dynamic state() => tester.state(find.byType(FadeInImage));

      RawImage displayedImage() => tester.widget(find.byType(RawImage));

      // The placeholder is expected to be already loaded
      final TestImageProvider placeholderProvider = new TestImageProvider(placeholderImage);

      // Test case: long loading image
      final TestImageProvider imageProvider = new TestImageProvider(targetImage);

      await tester.pumpWidget(new FadeInImage(
        placeholder: placeholderProvider,
        image: imageProvider,
        fadeOutDuration: const Duration(milliseconds: 50),
        fadeInDuration: const Duration(milliseconds: 50),
      ));

37
      expect(displayedImage().image, null); // image providers haven't completed yet
38 39 40
      placeholderProvider.complete();
      await tester.pump();

41
      expect(displayedImage().image, same(placeholderImage)); // placeholder completed
42 43
      expect(state().phase, FadeInImagePhase.waiting);

44 45
      imageProvider.complete(); // load the image
      expect(state().phase, FadeInImagePhase.fadeOut); // fade out placeholder
46 47 48 49 50
      for (int i = 0; i < 7; i += 1) {
        expect(displayedImage().image, same(placeholderImage));
        await tester.pump(const Duration(milliseconds: 10));
      }
      expect(displayedImage().image, same(targetImage));
51
      expect(state().phase, FadeInImagePhase.fadeIn); // fade in image
52 53 54 55
      for (int i = 0; i < 6; i += 1) {
        expect(displayedImage().image, same(targetImage));
        await tester.pump(const Duration(milliseconds: 10));
      }
56
      expect(state().phase, FadeInImagePhase.completed); // done
57 58 59 60 61 62 63 64 65 66
      expect(displayedImage().image, same(targetImage));

      // Test case: re-use state object (didUpdateWidget)
      final dynamic stateBeforeDidUpdateWidget = state();
      await tester.pumpWidget(new FadeInImage(
        placeholder: placeholderProvider,
        image: imageProvider,
      ));
      final dynamic stateAfterDidUpdateWidget = state();
      expect(stateAfterDidUpdateWidget, same(stateBeforeDidUpdateWidget));
67
      expect(stateAfterDidUpdateWidget.phase, FadeInImagePhase.completed); // completes immediately
68 69 70 71
      expect(displayedImage().image, same(targetImage));

      // Test case: new state object but cached image
      final dynamic stateBeforeRecreate = state();
72
      await tester.pumpWidget(new Container()); // clear widget tree to prevent state reuse
73 74 75 76 77 78 79
      await tester.pumpWidget(new FadeInImage(
        placeholder: placeholderProvider,
        image: imageProvider,
      ));
      expect(displayedImage().image, same(targetImage));
      final dynamic stateAfterRecreate = state();
      expect(stateAfterRecreate, isNot(same(stateBeforeRecreate)));
80
      expect(stateAfterRecreate.phase, FadeInImagePhase.completed); // completes immediately
81 82 83 84
      expect(displayedImage().image, same(targetImage));
    });
  });
}