glean/CHANGELOG.md

401 строка
20 KiB
Markdown
Исходник Обычный вид История

2019-10-03 13:42:19 +03:00
# Unreleased changes
2020-05-11 12:44:25 +03:00
[Full changelog](https://github.com/mozilla/glean/compare/v29.1.0...master)
2020-05-13 12:04:33 +03:00
* General:
* We completely replaced how the upload mechanism works.
glean-core (the Rust part) now controls all upload and coordinates the platform side with its own internals.
All language bindings implement ping uploading around a common API and protocol.
There is no change for users of Glean, the language bindings for Android and iOS have been adopted to the new mechanism already.
* Expose `RecordedEvent` and `DistributionData` types to Rust consumers ([#876](https://github.com/mozilla/glean/pull/876))
* Log crate version at initialize ([#873](https://github.com/mozilla/glean/pull/873))
* Android:
* Refactor the ping uploader to use the new upload mechanism.
* iOS:
* Refactor the ping uploader to use the new upload mechanism.
2020-05-11 12:44:25 +03:00
# v29.1.0 (2020-05-11)
[Full changelog](https://github.com/mozilla/glean/compare/v29.0.0...v29.1.0)
2020-05-05 15:05:33 +03:00
* General:
* The version of glean_parser has been upgraded to v1.20.4
* BUGFIX: `yamllint` errors are now reported using the correct file name.
* The minimum and maximum values of a timing distribution can now be controlled by the `time_unit` parameter. See [bug 1630997](https://bugzilla.mozilla.org/show_bug.cgi?id=1630997) for more details.
2020-05-05 15:05:33 +03:00
# v29.0.0 (2020-05-05)
[Full changelog](https://github.com/mozilla/glean/compare/v28.0.0...v29.0.0)
2020-04-24 22:41:59 +03:00
* General:
2020-05-05 14:05:04 +03:00
* The version of glean_parser has been upgraded to v1.20.2 ([#827](https://github.com/mozilla/glean/pull/827)):
* **Breaking change:** glinter errors found during code generation will now return an error code.
* `glean_parser` now produces a linter warning when `user` lifetime metrics are set to expire. See [bug 1604854](https://bugzilla.mozilla.org/show_bug.cgi?id=1604854) for additional context.
2020-05-13 12:04:33 +03:00
* Android:
2020-05-05 14:05:04 +03:00
* The `PingType.submit()` can now be called without a `null` by Java consumers ([#853](https://github.com/mozilla/glean/pull/853)).
* Python:
2020-05-05 14:05:04 +03:00
* BUGFIX: Fixed a race condition in the `atexit` handler, that would have resulted in the message "No database found" ([#854](https://github.com/mozilla/glean/pull/854)).
* The Glean FFI header is now parsed at build time rather than runtime. Relevant for packaging in `PyInstaller`, the wheel no longer includes `glean.h` and adds `_glean_ffi.py` ([#852](https://github.com/mozilla/glean/pull/852)).
* The minimum versions of many secondary dependencies have been lowered to make the Glean SDK compatible with more environments.
2020-05-05 14:05:04 +03:00
* Dependencies that depend on the version of Python being used are now specified using the [Declaring platform specific dependencies syntax in setuptools](https://setuptools.readthedocs.io/en/latest/setuptools.html#declaring-platform-specific-dependencies). This means that more recent versions of dependencies are likely to be installed on Python 3.6 and later, and unnecessary backport libraries won't be installed on more recent Python versions.
* iOS:
2020-05-05 14:05:04 +03:00
* Glean for iOS is now being built with Xcode 11.4.1 ([#856](https://github.com/mozilla/glean/pull/856))
2020-04-24 22:41:59 +03:00
# v28.0.0 (2020-04-23)
[Full changelog](https://github.com/mozilla/glean/compare/v27.1.0...v28.0.0)
2020-04-09 17:23:50 +03:00
* General:
* The baseline ping is now sent when the application goes to foreground, in addition to background and dirty-startup.
* Python:
* BUGFIX: The ping uploader will no longer display a trace back when the upload fails due to a failed DNS lookup, network outage, or related issues that prevent communication with the telemetry endpoint.
* The dependency on `inflection` has been removed.
* The Python bindings now use `subprocess` rather than `multiprocessing` to perform ping uploading in a separate process. This should be more compatible on all of the platforms Glean supports.
2020-04-09 17:23:50 +03:00
# v27.1.0 (2020-04-09)
[Full changelog](https://github.com/mozilla/glean/compare/v27.0.0...v27.1.0)
2020-04-08 12:10:57 +03:00
* General:
2020-04-09 17:23:13 +03:00
* BUGFIX: baseline pings sent at startup with the `dirty_startup` reason will now include application lifetime metrics ([#810](https://github.com/mozilla/glean/pull/810))
* iOS:
* **Breaking change:** Change Glean iOS to use Application Support directory [#815](https://github.com/mozilla/glean/pull/815). No migration code is included. This will reset collected data if integrated without migration. Please [contact the Glean SDK team](https://github.com/mozilla/glean#contact) if this affects you.
2020-04-09 17:01:57 +03:00
* Python
* BUGFIX: Fixed a race condition between uploading pings and deleting the temporary directory on shutdown of the process.
2020-04-08 12:10:57 +03:00
# v27.0.0 (2020-04-08)
[Full changelog](https://github.com/mozilla/glean/compare/v26.0.0...v27.0.0)
2020-03-28 01:06:09 +03:00
* General
* Glean will now detect when the upload enabled flag changes outside of the application, for example due to a change in a config file. This means that if upload is disabled while the application wasn't running (e.g. between the runs of a Python command using the Glean SDK), the database is correctly cleared and a deletion request ping is sent. See [#791](https://github.com/mozilla/glean/pull/791).
* The `events` ping now includes a reason code: `startup`, `background` or `max_capacity`.
* iOS:
* BUGFIX: A bug where the metrics ping is sent immediately at startup on the last day of the month has been fixed.
* Glean for iOS is now being built with Xcode 11.4.0
* The `measure` convenience function on timing distributions and time spans will now cancel the timing if the measured function throws, then rethrow the exception ([#808](https://github.com/mozilla/glean/pull/808))
2020-04-08 12:17:03 +03:00
* Broken doc generation has been fixed ([#805](https://github.com/mozilla/glean/pull/805)).
* Kotlin
* The `measure` convenience function on timing distributions and time spans will now cancel the timing if the measured function throws, then rethrow the exception ([#808](https://github.com/mozilla/glean/pull/808))
* Python:
* Glean will now wait at application exit for up to one second to let its worker thread complete.
* Ping uploading now happens in a separate child process by default. This can be disabled with the `allow_multiprocessing` configuration option.
2020-03-28 01:06:09 +03:00
# v26.0.0 (2020-03-27)
[Full changelog](https://github.com/mozilla/glean/compare/v25.1.0...v26.0.0)
2020-02-26 18:26:17 +03:00
* General:
* The version of `glean_parser` has been updated to 1.19.0:
* **Breaking change:** The regular expression used to validate labels is
stricter and more correct.
* Add more information about pings to markdown documentation:
* State whether the ping includes client id;
* Add list of data review links;
* Add list of related bugs links.
* `glean_parser` now makes it easier to write external translation functions for
different language targets.
* BUGFIX: glean_parser now works on 32-bit Windows.
* Android:
* `gradlew clean` will no longer remove the Miniconda installation in
`~/.gradle/glean`. Therefore `clean` can be used without reinstalling
Miniconda afterward every time.
* Python:
* **Breaking Change**: The `glean.util` and `glean.hardware` modules, which
were unintentionally public, have been made private.
* Most Glean work and I/O is now done on its own worker thread. This brings the parallelism Python in line with the other platforms.
* The timing distribution, memory distribution, string list, labeled boolean and labeled string metric types are now supported in Python ([#762](https://github.com/mozilla/glean/pull/762), [#763](https://github.com/mozilla/glean/pull/763), [#765](https://github.com/mozilla/glean/pull/765), [#766](https://github.com/mozilla/glean/pull/766))
2020-02-26 18:26:17 +03:00
# v25.1.0 (2020-02-26)
[Full changelog](https://github.com/mozilla/glean/compare/v25.0.0...v25.1.0)
2020-02-17 13:38:29 +03:00
* Python:
* The Boolean, Datetime and Timespan metric types are now supported in Python ([#731](https://github.com/mozilla/glean/pull/731), [#732](https://github.com/mozilla/glean/pull/732), [#737](https://github.com/mozilla/glean/pull/737))
* Make public, document and test the debugging features ([#733](https://github.com/mozilla/glean/pull/733))
2020-02-17 13:38:29 +03:00
# v25.0.0 (2020-02-17)
[Full changelog](https://github.com/mozilla/glean/compare/v24.2.0...v25.0.0)
2020-02-11 19:45:51 +03:00
2020-01-24 16:52:04 +03:00
* General:
* `ping_type` is not included in the `ping_info` any more ([#653](https://github.com/mozilla/glean/pull/653)), the pipeline takes the value from the submission URL.
* The version of `glean_parser` has been upgraded to 1.18.2:
* **Breaking Change (Java API)** Have the metrics names in Java match the names in Kotlin.
See [Bug 1588060](https://bugzilla.mozilla.org/show_bug.cgi?id=1588060).
* The reasons a ping are sent are now included in the generated markdown documentation.
2020-01-23 20:15:24 +03:00
* Android:
* The `Glean.initialize` method runs mostly off the main thread ([#672](https://github.com/mozilla/glean/pull/672)).
* Labels in labeled metrics now have a correct, and slightly stricter, regular expression.
See [label format](https://mozilla.github.io/glean/user/metrics/index.html#label-format) for more information.
* iOS:
* The baseline ping will now include `reason` codes that indicate why it was
submitted. If an unclean shutdown is detected (e.g. due to force-close), this
ping will be sent at startup with `reason: dirty_startup`.
2020-02-12 19:04:24 +03:00
* Per [Bug 1614785](https://bugzilla.mozilla.org/show_bug.cgi?id=1614785), the
clearing of application lifetime metrics now occurs after the metrics ping is
sent in order to preserve values meant to be included in the startup metrics
ping.
* `initialize()` now performs most of its work in a background thread.
* Python:
* When the pre-init task queue overruns, this is now recorded in the metric
`glean.error.preinit_tasks_overflow`.
* glinter warnings are printed to `stderr` when loading `metrics.yaml` and
`pings.yaml` files.
2020-01-24 16:52:04 +03:00
2020-02-11 19:45:51 +03:00
# v24.2.0 (2020-02-11)
[Full changelog](https://github.com/mozilla/glean/compare/v24.1.0...v24.2.0)
2020-01-16 23:30:50 +03:00
* General:
* Add `locale` to `client_info` section.
* **Deprecation Warning** Since `locale` is now in the `client_info` section, the one
in the baseline ping ([`glean.baseline.locale`](https://github.com/mozilla/glean/blob/c261205d6e84d2ab39c50003a8ffc3bd2b763768/glean-core/metrics.yaml#L28-L42))
is redundant and will be removed by the end of the quarter.
2020-01-22 18:01:44 +03:00
* Drop the Glean handle and move state into glean-core ([#664](https://github.com/mozilla/glean/pull/664))
* If an experiment includes no `extra` fields, it will no longer include `{"extra": null}` in the JSON payload.
* Support for ping `reason` codes was added.
* The metrics ping will now include `reason` codes that indicate why it was
submitted.
* The version of `glean_parser` has been upgraded to 1.17.3
* Android:
* Collections performed before initialization (preinit tasks) are now dispatched off
the main thread during initialization.
2020-02-11 18:16:45 +03:00
* The baseline ping will now include `reason` codes that indicate why it was
submitted. If an unclean shutdown is detected (e.g. due to force-close), this
ping will be sent at startup with `reason: dirty_startup`.
2020-01-21 19:03:01 +03:00
* iOS:
* Collections performed before initialization (preinit tasks) are now dispatched off
the main thread and not awaited during initialization.
* Added recording of `glean.error.preinit_tasks_overflow` to report when
the preinit task queue overruns, leading to data loss. See [bug
1609734](https://bugzilla.mozilla.org/show_bug.cgi?id=1609734)
2020-01-16 23:30:50 +03:00
# v24.1.0 (2020-01-16)
[Full changelog](https://github.com/mozilla/glean/compare/v24.0.0...v24.1.0)
2020-01-14 17:22:59 +03:00
* General:
* Stopping a non started measurement in a timing distribution will now be reported
as an `invalid_state` error.
* Android:
* A new metric `glean.error.preinit_tasks_overflow` was added to report when
the preinit task queue overruns, leading to data loss. See [bug
1609482](https://bugzilla.mozilla.org/show_bug.cgi?id=1609482)
2020-01-14 17:22:59 +03:00
# v24.0.0 (2020-01-14)
[Full changelog](https://github.com/mozilla/glean/compare/v23.0.1...v24.0.0)
2020-01-08 21:45:15 +03:00
* General:
* **Breaking Change** An `enableUpload` parameter has been added to the `initialize()`
function. This removes the requirement to call `setUploadEnabled()` prior to calling
the `initialize()` function.
* Android:
* The metrics ping scheduler will now only send metrics pings while the
application is running. The application will no longer "wake up" at 4am
using the Work Manager.
2020-01-08 18:25:13 +03:00
* The code for migrating data from Glean SDK before version 19 was removed.
2020-01-13 13:49:14 +03:00
* When using the `GleanTestLocalServer` rule in instrumented tests, pings are
immediately flushed by the `WorkManager` and will reach the test endpoint as
soon as possible.
* Python:
* The Python bindings now support Python 3.5 - 3.7.
* The Python bindings are now distributed as a wheel on Linux, macOS and
Windows.
# v23.0.1 (2020-01-08)
[Full changelog](https://github.com/mozilla/glean/compare/v23.0.0...v23.0.1)
* Android:
* BUGFIX: The Glean Gradle plugin will now work if an app or library doesn't
have a metrics.yaml or pings.yaml file.
* iOS:
2020-01-13 13:37:51 +03:00
* The released iOS binaries are now built with Xcode 11.3.
# v23.0.0 (2020-01-07)
[Full changelog](https://github.com/mozilla/glean/compare/v22.1.0...v23.0.0)
2019-12-05 13:21:52 +03:00
* Python bindings:
* Support for events and UUID metrics was added.
* Android:
2019-12-11 19:02:47 +03:00
* The Glean Gradle Plugin correctly triggers docs and API updates when registry files
change, without requiring them to be deleted.
* `parseISOTimeString` has been made 4x faster. This had an impact on Glean
migration and initialization.
* Metrics with `lifetime: application` are now cleared when the application is started,
after startup Glean SDK pings are generated.
* All platforms:
* The public method `PingType.send()` (in all platforms) have been deprecated
and renamed to `PingType.submit()`.
* Rename `deletion_request` ping to `deletion-request` ping after glean_parser update
# v22.1.0 (2019-12-17)
[Full changelog](https://github.com/mozilla/glean/compare/v22.0.0...v22.1.0)
* Add `InvalidOverflow` error to `TimingDistribution`s ([#583](https://github.com/mozilla/glean/pull/583))
2019-12-05 13:21:52 +03:00
# v22.0.0 (2019-12-05)
[Full changelog](https://github.com/mozilla/glean/compare/v21.3.0...v22.0.0)
2019-12-05 13:21:52 +03:00
* Add option to defer ping lifetime metric persistence ([#530](https://github.com/mozilla/glean/pull/530))
* Add a crate for the nice control API ([#542](https://github.com/mozilla/glean/pull/542))
* Pending `deletion_request` pings are resent on start ([#545](https://github.com/mozilla/glean/pull/545))
2019-12-03 12:22:51 +03:00
# v21.3.0 (2019-12-03)
[Full changelog](https://github.com/mozilla/glean/compare/v21.2.0...v21.3.0)
2019-11-21 21:49:28 +03:00
2019-12-03 12:22:32 +03:00
* Timers are reset when disabled. That avoids recording timespans across disabled/enabled toggling ([#495](https://github.com/mozilla/glean/pull/495)).
* Add a new flag to pings: `send_if_empty` ([#528](https://github.com/mozilla/glean/pull/528))
* Upgrade `glean_parser` to v1.12.0
* Implement the deletion request ping in Glean ([#526](https://github.com/mozilla/glean/pull/526))
2019-11-28 13:23:18 +03:00
2019-11-21 21:49:28 +03:00
# v21.2.0 (2019-11-21)
[Full changelog](https://github.com/mozilla/glean/compare/v21.1.1...v21.2.0)
2019-11-20 20:40:44 +03:00
* All platforms
* The experiments API is no longer ignored before the Glean SDK initialized. Calls are
recorded and played back once the Glean SDK is initialized.
* String list items were being truncated to 20, rather than 50, bytes when using
`.set()` (rather than `.add()`). This has been corrected, but it may result
in changes in the sent data if using string list items longer than 20 bytes.
2019-11-20 20:40:44 +03:00
# v21.1.1 (2019-11-20)
[Full changelog](https://github.com/mozilla/glean/compare/v21.1.0...v21.1.1)
* Android:
2019-11-28 13:23:18 +03:00
* Use the `LifecycleEventObserver` interface, rather than the `DefaultLifecycleObserver`
interface, since the latter isn't compatible with old SDK targets.
# v21.1.0 (2019-11-20)
[Full changelog](https://github.com/mozilla/glean/compare/v21.0.0...v21.1.0)
2019-11-11 17:31:49 +03:00
* Android:
* Two new metrics were added to investigate sending of metrics and baseline pings.
See [bug 1597980](https://bugzilla.mozilla.org/show_bug.cgi?id=1597980) for more information.
* Glean's two lifecycle observers were refactored to avoid the use of reflection.
* All platforms:
* Timespans will now not record an error if stopping after setting upload enabled to false.
2019-11-18 17:46:10 +03:00
# v21.0.0 (2019-11-18)
[Full changelog](https://github.com/mozilla/glean/compare/v20.2.0...v21.0.0)
* Android:
* The `GleanTimerId` can now be accessed in Java and is no longer a `typealias`.
* Fixed a bug where the metrics ping was getting scheduled twice on startup.
* All platforms
* Bumped `glean_parser` to version 1.11.0.
2019-11-13 14:00:26 +03:00
2019-11-11 18:16:32 +03:00
# v20.2.0 (2019-11-11)
2019-11-18 17:46:10 +03:00
[Full changelog](https://github.com/mozilla/glean/compare/v20.1.0...v20.2.0)
2019-11-11 18:16:32 +03:00
* In earlier 20.x.x releases, the version of glean-ffi was incorrectly built
against the wrong version of glean-core.
2019-11-11 17:31:49 +03:00
# v20.1.0 (2019-11-11)
[Full changelog](https://github.com/mozilla/glean/compare/v20.0.0...v20.1.0)
* The version of Glean is included in the Glean Gradle plugin.
2019-11-11 16:43:54 +03:00
* When constructing a ping, events are now sorted by their timestamp. In practice,
it rarely happens that event timestamps are unsorted to begin with, but this
guards against a potential race condition and incorrect usage of the lower-level
API.
2019-11-11 16:43:54 +03:00
# v20.0.0 (2019-11-11)
[Full changelog](https://github.com/mozilla/glean/compare/v19.1.0...v20.0.0)
* Glean users should now use a Gradle plugin rather than a Gradle script. (#421)
See [integrating with the build system docs](https://mozilla.github.io/glean/book/user/adding-glean-to-your-project.html#integrating-with-the-build-system) for more information.
2019-10-29 19:26:02 +03:00
2019-11-01 16:19:41 +03:00
* In Kotlin, metrics that can record errors now have a new testing method,
2019-11-11 16:43:54 +03:00
`testGetNumRecordedErrors`. (#401)
2019-11-01 16:19:41 +03:00
2019-10-29 19:26:02 +03:00
# v19.1.0 (2019-10-29)
[Full changelog](https://github.com/mozilla/glean/compare/v19.0.0...v19.1.0)
2019-10-21 15:40:13 +03:00
* Fixed a crash calling `start` on a timing distribution metric before Glean is initialized.
2019-10-24 16:45:41 +03:00
Timings are always measured, but only recorded when upload is enabled ([#400](https://github.com/mozilla/glean/pull/400))
* BUGFIX: When the Debug Activity is used to log pings, each ping is now logged only once ([#407](https://github.com/mozilla/glean/pull/407))
* New `invalid state` error, used in timespan recording ([#230](https://github.com/mozilla/glean/pull/230))
* Add an Android crash instrumentation walk-through ([#399](https://github.com/mozilla/glean/pull/399))
* Fix crashing bug by avoiding assert-printing in LMDB ([#422](https://github.com/mozilla/glean/pull/422))
2019-10-29 19:26:02 +03:00
* Upgrade dependencies, including rkv ([#416](https://github.com/mozilla/glean/pull/416))
2019-10-21 15:40:13 +03:00
# v19.0.0 (2019-10-22)
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING6...v19.0.0)
First stable release of Glean in Rust (aka glean-core).
This is a major milestone in using a cross-platform implementation of Glean on the Android platform.
* Fix round-tripping of timezone offsets in dates ([#392](https://github.com/mozilla/glean/pull/392))
2019-10-21 15:40:13 +03:00
* Handle dynamic labels in coroutine tasks ([#394](https://github.com/mozilla/glean/pull/384))
2019-10-18 17:30:17 +03:00
# v0.0.1-TESTING6 (2019-10-18)
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING5...v0.0.1-TESTING6)
* Ignore dynamically stored labels if Glean is not initialized ([#374](https://github.com/mozilla/glean/pull/374))
* Make sure ProGuard doesn't remove Glean classes from the app ([#380](https://github.com/mozilla/glean/pull/380))
* Keep track of pings in all modes ([#378](https://github.com/mozilla/glean/pull/378))
* Add `jnaTest` dependencies to the `forUnitTest` JAR ([#382](https://github.com/mozilla/glean/pull/382))
2019-10-18 17:30:17 +03:00
# v0.0.1-TESTING5 (2019-10-10)
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING4...v0.0.1-TESTING5)
* Upgrade to NDK r20 ([#365](https://github.com/mozilla/glean/pull/365))
2019-10-09 12:59:09 +03:00
# v0.0.1-TESTING4 (2019-10-09)
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING3...v0.0.1-TESTING4)
* Take DST into account when converting a calendar into its items ([#359](https://github.com/mozilla/glean/pull/359))
* Include a macOS library in the `forUnitTests` builds ([#358](https://github.com/mozilla/glean/pull/358))
* Keep track of all registered pings in test mode ([#363](https://github.com/mozilla/glean/pull/363))
2019-10-08 21:58:32 +03:00
# v0.0.1-TESTING3 (2019-10-08)
2019-10-09 12:59:09 +03:00
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING2...v0.0.1-TESTING3)
* Allow configuration of Glean through the `GleanTestRule`
2019-10-09 12:59:09 +03:00
* Bump `glean_parser` version to 1.9.2
# v0.0.1-TESTING2 (2019-10-07)
[Full changelog](https://github.com/mozilla/glean/compare/v0.0.1-TESTING1...v0.0.1-TESTING2)
* Include a Windows library in the `forUnitTests` builds
2019-10-03 13:42:19 +03:00
# v0.0.1-TESTING1 (2019-10-02)
[Full changelog](https://github.com/mozilla/glean/compare/95b6bcc03616c8d7c3e3e64e99ee9953aa06a474...v0.0.1-TESTING1)
### General
First testing release.