Skip to content

Change Log

Unreleased

1.3.4 - 2024-05-23

New

  • Support for animated-PNG-based snapshots using Paparazzi#gif
  • New tasks! deletePaparazziSnapshots and cleanRecordPaparazzi${VARIANT} clear orphaned snapshots
  • Add boolean flag to decide if image should be scaled or full-sized
  • Migrate Paparazzi to layoutlib Iguana 2023.2.1
  • Compose 1.5.14
  • Kotlin 1.9.24
  • [Gradle Plugin] Gradle 8.7
  • [Gradle Plugin] Android Gradle Plugin 8.3.2

Fixed

  • Fix long content description being cut off in accessibility snapshots
  • Include resource references from generated resource folders
  • Fix gradle caching for resources coming from aar dependencies
  • Support SHRINK render mode when using unsafeUpdateConfig
  • Fix issue where multiple snapshots fail when using render extensions
  • Remove guava workaround from 1.3.2 now that Collector APIs are in guava-android

Kudos to @geoff-powell, @gamepro65, @kevinzheng-ap, @nak5ive, @TWiStErRob, @emuguy1 and others for contributions this release!

1.3.3 - 2024-03-01

New

  • Migrate Paparazzi to layoutlib Hedgehog 2023.1.1
  • Compose 1.5.8
  • Kotlin 1.9.22
  • [Gradle Plugin] Gradle 8.6
  • [Gradle Plugin] Android Gradle Plugin 8.2.1

Fixed

  • Update the DeviceConfig screenWidth internally for accessibility tests
  • Fix variant caching issues in new resource/asset loading mechanisms
  • Remove legacy resources/assets loading mechanism
  • Set HardwareConfig width and height based on orientation
  • Apply round screen qualifier to device config
  • Restrict Paparazzi’s public API
  • Remove obsolete NEXUS_5_LAND DeviceConfig
  • Fix formatting so that all digits show upon failure
  • Stop resolving dependencies at configuration time
  • Use our own internal HandlerDispatcher for Compose Ui tests
  • Include generated string resources
  • Reset logger to prevent swallowing exceptions

Kudos to @gamepro65, @kevinzheng-ap, @BrianGardnerAtl, @adamalyyan, and others for contributions this release!

1.3.2 - 2024-01-13

NOTE: Due to a known issue with how Guava now publishes its artifact, you will need to apply the following snippet workaround to your root build.gradle:

subprojects {
  plugins.withId("app.cash.paparazzi") {
    // Defer until afterEvaluate so that testImplementation is created by Android plugin.
    afterEvaluate {
      dependencies.constraints {
        add("testImplementation", "com.google.guava:guava") {
          attributes {
            attribute(
              TargetJvmEnvironment.TARGET_JVM_ENVIRONMENT_ATTRIBUTE,
              objects.named(TargetJvmEnvironment, TargetJvmEnvironment.STANDARD_JVM)
            )
          }
          because("LayoutLib and sdk-common depend on Guava's -jre published variant." +
            "See https://github.com/cashapp/paparazzi/issues/906.")
        }
      }
    }
  }
}
See also: https://github.com/google/guava/issues/6801.

New

  • Support for pseudolocalization tests! To get started:

    @RunWith(TestParameterInjector::class)
    class PseudolocalizationTest(
      @TestParameter locale: Locale
    ) {
      @get:Rule val paparazzi = Paparazzi(
        deviceConfig = DeviceConfig.PIXEL_5.copy(locale = locale.tag)
      )
    
      @Test fun test() {
        paparazzi.snapshot { SomeComposable() }
      }
    
      enum class Locale(val tag: String?) {
        Default(null),
        Accent("en-rXA"),
        Bidi("ar-rXB")
      }
    }
    

  • Migrate Paparazzi to layoutlib Giraffe 2022.3.1

  • Compose 1.5.0
  • Kotlin 1.9.0
  • [Gradle Plugin] Gradle 8.5
  • [Gradle Plugin] Android Gradle Plugin 8.1.1

Fixed

  • Fix relativePath bug in port of ResourceFile
  • Resolve report dir from ReportingExtension instead of hardcoding
  • Make report folder variant-aware
  • Remove reliance on kotlinx.coroutines.main.delay
  • Use a class file locator that queries the system class loader
  • Filter out unrecognized java-symbol tag warning
  • Skip synthetic fields in R classes
  • Update task inputs for resources and assets to account for file renames and moves
  • Update delta images to support showing diff when width and height differ

Kudos to @kevinzheng-ap, @TWiStErRob, @gamepro65, @adamalyyan, @larryng, and others for contributions this release!

1.3.1 - 2023-07-18

New

  • Migrated to new resource and asset loading mechanisms. To explicitly opt-out and fall back to the legacy mechanisms, add either/both of the following to your gradle.properties:

    app.cash.paparazzi.legacy.resource.loading=true
    app.cash.paparazzi.legacy.asset.loading=true
    

  • The Android system ui (status + navigation bar) is now hidden by default; to re-enable:

      @get:Rule
      val paparazzi = Paparazzi(
        showSystemUi = true
      )
    

  • Relocate failure deltas from PROJECT_ROOT/out/failures/ to BUILD_DIR/paparazzi/failures/

  • Support for application and dynamic feature modules
  • [Gradle Plugin] Gradle 8.2.1

Fixed

  • Fix accessibility labels when mergeDescendants is true
  • Fixes compose alert dialogs not rendering when using RenderingMode.SHRINK

Kudos to @kevinzheng-ap, @adamalyyan and others for contributions this release!

1.3.0 - 2023-05-31

As of this release, consumers must build on Java 17+ environments.

New

  • Migrate Paparazzi to layoutlib Flamingo 2022.2.1
  • Add accessibility support for Composables
  • Add layout accessibility check support
  • Compose 1.4.7
  • Kotlin 1.8.21
  • [Gradle Plugin] Gradle 8.1.1
  • [Gradle Plugin] Android Gradle Plugin 8.0.2

Fixed

  • Configure android.os.Build values via reflection
  • Various bug fixes with AccessibilityRenderExtension
  • Make sure changes to system properties actually affect test tasks
  • Fix caching bug with preparePaparazziResources task
  • Use Dispatchers.Main for delay functionality
  • Recomposition does not happen unless lifecycle is RESUMED
  • Fix NPE when unit test variant is disabled
  • Fix incompatibility with androidx.savedstate:1.1.0

Kudos to @gamepro65, @geoff-powell, @TWiStErRob, @adamalyyan and others for contributions this release!

1.2.0 - 2023-01-18

New

  • Migrate Paparazzi to layoutlib Electric Eel 2022.1.1
  • Add support for RenderingMode.SHRINK to allow view-only screenshots
  • Expose flag to show/hide system ui
  • Register a default OnBackPressedDispatcherOwner if its present in classpath
  • Bump default compileSdk to API 33
  • Compose 1.3.1
  • Kotlin 1.7.20
  • [Gradle Plugin] Gradle 7.6
  • [Gradle Plugin] Android Gradle Plugin 7.4.0

Fixed

  • Flush errors on unsafeUpdateConfig
  • Only apply wear circle shape to full device screenshots
  • Synchronize access to Handler_Delegate.queue
  • Apply compose hooks to all snapshot calls
  • Register LifecycleOwner and SavedStateRegistryOwner to all views
  • Execute Handler callbacks after snapshots to clean up Compose references
  • Fix RecyclerView issue due to layoutlib Dolphin update
  • Keep AGP and tools dependencies aligned

Kudos to @gamepro65, @saket, @rharter and others for contributions this release!

1.1.0 - 2022-10-12

New

  • Migrate Paparazzi to layoutlib Chipmunk 2021.2.1
  • Add support for multiplatform plugin
  • Add support for JDKs 16+
  • Add support for locales and layout direction (LTR/RTL)
  • Add Pixel 6 & Pixel 6 Pro device configs
  • Enable night mode for legacy views and composables
  • Enable ui mode to support form factors other than phones/tablets, e.g., auto, watches, etc.
  • Google Wear DeviceConfig support
  • Expose an API for offsetting frame capture time
  • Add InstantAnimationsRule to delay snapshot capture until the last frame.
  • Compose 1.3.0
  • Kotlin 1.7.10
  • [Gradle Plugin] Gradle 7.5.1

Fixed

  • Generate resource ids to support aapt inline resources in composables
  • Reset AndroidUiDispatcher between compose snapshots
  • Fix OOM error when a large number of compose snapshots are verified
  • Fix HTML report in development mode
  • Honor customization of Gradle’s build output directory
  • [Gradle Plugin] Configure native platform transformed path directly in test task to reduce cache misses
  • [Gradle Plugin] Fix accidental eager task creation reducing memory pressure
  • [Gradle Plugin] Fail explicitly when applying Android application plugin

Kudos to @chris-horner, @swankjesse, @yschimke, @dniHze, @TWiStErRob, @gamepro65, @liutikas and others for contributions this release!

1.0.0 - 2022-06-03

New

  • Support for Composable snapshots
  • Migrate Paparazzi to layoutlib Bumblebee 2021.1.1 for better rendering and API 31 support
  • Update Paparazzi configuration via new unsafeUpdateConfig method instead of snapshot/gif
  • Cache Paparazzi bootstrap logic for better performance per test suite
  • Surface internally thrown exceptions from layoutlib
  • Throw a more helpful exception if Android platform is missing
  • Bump default compileSdk to API 31
  • Compose 1.1.1
  • Kotlin 1.6.10
  • [Gradle Plugin] Gradle 7.4.2
  • [Gradle Plugin] Android Gradle Plugin 7.1.2

Fixed

  • Prepend paths with file:// for clickable error output in IDE
  • Update default SDK path on Linux
  • Fix accessibility test logic to avoid unnecessary coloring changes on updated view ids
  • Fixes crash when using InputMethodManager to show/hide keyboard
  • Temporarily work around Compose runtime memory leaks
  • [Gradle Plugin] Prefer namespace DSL declaration over manifest package declaration
  • [Gradle Plugin] Publish plugin marker on snapshot builds
  • [Gradle Plugin] Exclude androidTest sourceSets during paparazzi runs

Kudos to @luis-cortes, @nak5ive, @alexvanyo, @gamepro65 and others for contributions this release!

0.9.3 - 2022-01-20

Fixed

  • Load the correct mac arm artifact on M1 machines
  • Generate fake View.id for consistent colors for accessibility entries when views are modified

Kudos to @geoff-powell, @nicbell for their contributions this release!

0.9.2 - 2022-01-20

Please ignore this release

0.9.1 - 2022-01-14

Fixed

  • Download mac arm artifact if on M1 machines
  • Support for assets from transitive dependencies
  • Add fix for ClassNotFoundException when using nonTransitiveRClass
  • Update RELEASING notes to publish plugin marker artifact
  • Avoid NPE in AccessibilityRenderExtension when layout params are not supplied
  • Use View.id to generate consistent colors for accessibility entries when views are modified

Kudos to @luis-cortes, @geoff-powell, @autonomousapps and @LuK1709 for their contributions this release!

0.9.0 - 2021-11-22

New

  • Migrate Paparazzi to layoutlib Arctic Fox 2020.3.1, providing native support for M1 machines
  • Migrate Paparazzi to layoutlib 4.2, unlocking future Compose support
  • Add support for projects enabling non-transitive resources
  • RenderExtension now visits view hierarchy pre-rendering instead of layering bitmaps post-rendering
  • Fail-fast when Bridge.init fails, usually due to native crash
  • Expose RenderingMode as a configurable option
  • Bump default compileSdk to API 30
  • Improve Java-interoperability experience
  • Kotlin 1.5.31

Fixed

  • Don’t require Android plugin to be declared before Paparazzi plugin
  • Clear AnimationHandler leak after each snapshot
  • Don’t generate empty mov files on snapshot failure
  • Add Kotlin platform bom to prevent classpath conflicts during test builds
  • Use correct default Android SDK path on Windows
  • Use platform-agnostic file paths in Gradle artifacts to support remote caching across platforms
  • Use platform-agnostic file paths in Javascript for web page support on Windows
  • Fix font scaling issue in AccessibilityRenderExtension by using bundled font

Kudos to @luis-cortes, @geoff-powell and @TWiStErRob for their contributions this release!

0.8.0 - 2021-10-07

New

  • Migrate Paparazzi to use native layoutlib for better rendering and API 30 support
  • Add new extension for rendering accessibility metadata
  • Add support for fontScale in DeviceConfig
  • Add device config for Pixel 5
  • Add tasks to Gradle task verification group
  • Migrate publishing to gradle-maven-publish-plugin
  • Migrate builds to Github Actions
  • Migrate sample test from Burst to TestParameterInjector
  • Kotlin 1.5.21
  • [Gradle Plugin] Support for configuration caching
  • [Gradle Plugin] Gradle 7.2

Fixed

  • Add method interceptor for matrix multiplication operations
  • Don’t swallow FileNotFoundExceptions when overridden platform dir doesn’t exist
  • [Gradle Plugin] Fix remote caching bug by referencing relative, not absolute, paths in intermediate resources file.

0.7.1 - 2021-05-17

New

  • [Gradle Plugin] Support the –tests option for record/verify tasks

Fixed

  • [Gradle Plugin] Defer task configuration until created

0.7.0 - 2021-02-26

New

  • Kotlin 1.4.30
  • Add support for inline complex XML resources
  • Enable Burst support
  • Expose maximum percentage difference in image verification as a setting
  • Render extension api to add extra information to snapshots
  • Allow selection of night mode in DeviceConfig
  • [Gradle Plugin] Gradle 6.8.3
  • [Gradle Plugin] Creating an umbrella task to execute on all variants

Fixed

  • Properly execute Choreographer.doFrame after view has been laid out
  • Fix broken text appearances when style resource names contain periods
  • Fix ability to access asset files
  • Use target-sdk to simulate device when available
  • Always write screenshots to disk in record mode
  • Don’t crash when running on Java 12+
  • [Gradle Plugin] Force test re-runs when a resource or asset has changed
  • [Gradle Plugin] Force test re-runs if generated report or snapshot dirs are deleted

0.6.0 - 2020-10-02

As of this release, consumers must build on Java 11 environments.

New

  • Point to a more recent version of layoutlib that runs on Android Q and builds with Java 11.
  • Refactor Paparazzi to better support non-Gradle builds
  • Added device configs for Pixel 4 series

0.5.2 - 2020-09-17

Fixed

  • [Gradle Plugin] Fixed record and verify tasks in multi-module projects.

0.5.1 - 2020-09-17

Fixed

  • [Gradle Plugin] Fixed race condition in record and verify tasks.

0.5.0 - 2020-09-16

  • Initial release.