From 69de3dc599b1f40c82d061c11e3ae259dfe22a90 Mon Sep 17 00:00:00 2001 From: Srikanth Chekuri Date: Fri, 24 Feb 2023 01:02:26 +0530 Subject: [PATCH 1/2] Update docs (#3188) * Update docs * fix spell --- CONTRIBUTING.md | 23 +++------ README.md | 130 ++++++++++++++++-------------------------------- rationale.md | 19 +++---- 3 files changed, 55 insertions(+), 117 deletions(-) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index e97e9daff22..daef82f90a6 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,12 +1,9 @@ # Contributing to opentelemetry-python -The Python special interest group (SIG) meets regularly. See the OpenTelemetry -[community](https://github.com/open-telemetry/community#python-sdk) repo for -information on this and other language SIGs. +The Python special interest group (SIG) meets weekly on Thursdays at 9AM PST. Check the [OpenTelemetry community calendar](https://calendar.google.com/calendar/embed?src=google.com_b79e3e90j7bbsa2n2p5an5lf60%40group.calendar.google.com) for specific dates and Zoom meeting links. See the [public meeting notes](https://docs.google.com/document/d/1CIMGoIOZ-c3-igzbd6_Pnxx1SjAkjwqoYSUWxPY8XIs/edit) -for a summary description of past meetings. To request edit access, join the -meeting or get in touch on [Slack](https://cloud-native.slack.com/archives/C01PD4HUVBL). +for a summary description of past meetings. See to the [community membership document](https://github.com/open-telemetry/community/blob/main/community-membership.md) on how to become a [**Member**](https://github.com/open-telemetry/community/blob/main/community-membership.md#member), @@ -19,13 +16,7 @@ This is the main repo for OpenTelemetry Python. Nevertheless, there are other re Please take a look at this list first, your contributions may belong in one of these repos better: 1. [OpenTelemetry Contrib](https://github.com/open-telemetry/opentelemetry-python-contrib): Instrumentations for third-party - libraries and frameworks. There is an ongoing effort to migrate into the OpenTelemetry Contrib repo some of the existing - programmatic instrumentations that are now in the `ext` directory in the main OpenTelemetry repo. Please ask in the Slack - channel (see below) for guidance if you want to contribute with these instrumentations. - -# Find the right branch - -The default branch for this repo is `main`. All feature work is accomplished on branches from `main`. + libraries and frameworks. ## Find a Buddy and get Started Quickly! @@ -75,8 +66,8 @@ An easier way to do so is: We try to keep the amount of _public symbols_ in our code minimal. A public symbol is any Python identifier that does not start with an underscore. Every public symbol is something that has to be kept in order to maintain backwards compatibility, so we try to have as few as possible. -To check if your PR is adding public symbols, run `tox -e public-symbols-check`. This will always fail if public symbols are being added. The idea -behind this is that every PR that adds public symbols fails in CI, forcing reviewers to check the symbols to make sure they are strictly necessary. +To check if your PR is adding public symbols, run `tox -e public-symbols-check`. This will always fail if public symbols are being added/removed. The idea +behind this is that every PR that adds/removes public symbols fails in CI, forcing reviewers to check the symbols to make sure they are strictly necessary. If after checking them, it is considered that they are indeed necessary, the PR will be labeled with `Skip Public API check` so that this check is not run. @@ -95,7 +86,7 @@ CONTRIB_REPO_SHA=dde62cebffe519c35875af6d06fae053b3be65ec tox ``` The continuation integration overrides that environment variable with as per the configuration -[here](https://github.com/open-telemetry/opentelemetry-python/blob/9020b0baaeb41b7137badca988bb5c2d562cddee/.github/workflows/test.yml#L13). +[here](https://github.com/open-telemetry/opentelemetry-python/blob/main/.github/workflows/test.yml#L13). ### Benchmarks @@ -196,7 +187,7 @@ updating the GitHub workflow to reference a PR in the Contrib repo * Trivial change (typo, cosmetic, doc, etc.) doesn't have to wait for one day. * Urgent fix can take exception as long as it has been actively communicated. -Any Approver / Maintainer can merge the PR once it is **ready to merge**. +One of the maintainers will merge the PR once it is **ready to merge**. ## Design Choices diff --git a/README.md b/README.md index ec94eb8fe22..1cad936e57c 100644 --- a/README.md +++ b/README.md @@ -1,50 +1,47 @@ -## OpenTelemetry Python ---- -

- - Getting Started -   •   - API Documentation -   •   - Getting In Touch (GitHub Discussions) - -

- -

- - GitHub release (latest by date including pre-releases) - - - Codecov Status - - - license - -
- - Build Status - - Beta -

- -

- - Contributing -   •   - Examples - -

- ---- - -This page describes the Python [OpenTelemetry](https://opentelemetry.io/) implementation. OpenTelemetry is an observability framework for cloud-native software. - -## Requirements -Unless otherwise noted, all published artifacts support Python 3.7 or higher. See CONTRIBUTING.md for additional instructions for building this project for development. +# OpenTelemetry Python +[![Slack](https://img.shields.io/badge/slack-@cncf/otel/python-brightgreen.svg?logo=slack)](https://cloud-native.slack.com/archives/C01PD4HUVBL) +[![Build Status](https://github.com/open-telemetry/opentelemetry-python/actions/workflows/test.yml/badge.svg?branch=main)](https://github.com/open-telemetry/opentelemetry-python/actions) +[![Minimum Python Version](https://img.shields.io/badge/python-3.7+-blue.svg)](https://www.python.org/downloads/) +[![Release](https://img.shields.io/github/v/release/open-telemetry/opentelemetry-python?include_prereleases&style=)](https://github.com/open-telemetry/opentelemetry-python/releases/) +[![Read the Docs](https://readthedocs.org/projects/opentelemetry-python/badge/?version=latest)](https://opentelemetry-python.readthedocs.io/en/latest/) + +## Project Status + +See the [OpenTelemetry Instrumentation for Python](https://opentelemetry.io/docs/instrumentation/python/#status-and-releases). + +| Signal | Status | Project | +| ------- | ------------ | ------- | +| Traces | Stable | N/A | +| Metrics | Stable | N/A | +| Logs | Experimental | N/A | + +Project versioning information and stability guarantees can be found [here](./rationale.md#versioning-and-releasing). ## Getting started -The goal of OpenTelemetry is to provide a single set of APIs to capture distributed traces and metrics from your application and send them to an observability platform. This project lets you do just that for applications written in Python. +You can find the getting started guide for OpenTelemetry Python [here](https://opentelemetry.io/docs/instrumentation/python/getting-started/). + +If you are looking for **examples** on how to use the OpenTelemetry API to +instrument your code manually, or how to set up the OpenTelemetry +Python SDK, see https://opentelemetry.io/docs/instrumentation/python/manual/. + +## Python Version Support + +This project ensures compatibility with the current supported versions of the Python. As new Python versions are released, support for them is added and +as old Python versions reach their end of life, support for them is removed. + +We add support for new Python versions no later than 3 months after they become stable. + +We remove support for old Python versions 6 months after they reach their [end of life](https://devguide.python.org/devcycle/#end-of-life-branches). + + +## Documentation + +The online documentation is available at https://opentelemetry-python.readthedocs.io/. +To access the latest version of the documentation, see +https://opentelemetry-python.readthedocs.io/en/latest/. + +## Install This repository includes multiple installable packages. The `opentelemetry-api` package includes abstract classes and no-op implementations that comprise the OpenTelemetry API following the @@ -91,47 +88,13 @@ pip install -e ./instrumentation/opentelemetry-instrumentation-{instrumentation} For additional exporter and instrumentation packages, see the [`opentelemetry-python-contrib`](https://github.com/open-telemetry/opentelemetry-python-contrib) repository. -## Running Performance Tests - -This section provides details on how to reproduce performance tests results on your own -machine. - -### Resource Usage Tests - -1. Install scalene using the following command - -```sh -pip install scalene -``` - -2. Run the `scalene` tests on any of the example Python programs - -```sh -scalene opentelemetry-/tests/performance/resource-usage//profile_resource_usage_.py -``` - -## Python Version Support Addition and Removal - -This project supports the latest Python versions. As new Python versions are released, support for them is added and -as old Python versions reach their end of life, support for them is removed. - -We add support for new Python versions no later than 3 months after they become stable. - -We remove support for old Python versions 6 months after they reach their [end of life](https://devguide.python.org/devcycle/#end-of-life-branches). - -## Documentation - -The online documentation is available at https://opentelemetry-python.readthedocs.io/. -To access the latest version of the documentation, see -https://opentelemetry-python.readthedocs.io/en/latest/. - ## Contributing For information about contributing to OpenTelemetry Python, see [CONTRIBUTING.md](CONTRIBUTING.md). We meet weekly on Thursdays at 9AM PST. The meeting is subject to change depending on contributors' availability. Check the [OpenTelemetry community calendar](https://calendar.google.com/calendar/embed?src=google.com_b79e3e90j7bbsa2n2p5an5lf60%40group.calendar.google.com) for specific dates and Zoom meeting links. -Meeting notes are available as a public [Google doc](https://docs.google.com/document/d/1CIMGoIOZ-c3-igzbd6_Pnxx1SjAkjwqoYSUWxPY8XIs/edit). For edit access, get in touch on [GitHub Discussions](https://github.com/open-telemetry/opentelemetry-python/discussions). +Meeting notes are available as a public [Google doc](https://docs.google.com/document/d/1CIMGoIOZ-c3-igzbd6_Pnxx1SjAkjwqoYSUWxPY8XIs/edit). Approvers ([@open-telemetry/python-approvers](https://github.com/orgs/open-telemetry/teams/python-approvers)): @@ -171,12 +134,3 @@ Emeritus Maintainers: - -## Project Status - -For project boards and milestones, see the following links: -- [Project boards](https://github.com/open-telemetry/opentelemetry-python/projects) -- [Milestones](https://github.com/open-telemetry/opentelemetry-python/milestones) - -We try to keep these links accurate, so they're the best place to go for questions about project status. The dates and features described in the issues -and milestones are estimates and subject to change. diff --git a/rationale.md b/rationale.md index 8ff92e902c7..4f1dd3ab82e 100644 --- a/rationale.md +++ b/rationale.md @@ -40,7 +40,7 @@ Pre-release packages are denoted by appending identifiers such as -Alpha, -Beta, ### Immature or experimental signals -Modules for experimental signals will be released in a separate versions that will be marked as pre-releases, and must be installed manually. Modules will remain at version v0.x.y to make it abundantly clear that depending on them is at your own risk. For example, the `opentelemetry-api` v0.x.y-b0 module will provide experimental access to the latest features in development, which will include the experimental metrics signals. Notice the `b0` suffix which indicates that the release is still in beta, and therefore deemed to be in pre-release. NO STABILITY GUARANTEES ARE MADE. +Modules for experimental signals will be released in the same packages as the core components, but prefixed with `_` to indicate that they are unstable and subject to change. NO STABILITY GUARANTEES ARE MADE. ## Examples @@ -53,13 +53,6 @@ Purely for illustration purposes, not intended to represent actual releases: - `opentelemetry-sdk` 1.0.0 - Contains SDK components for tracing, baggage, propagators, and context -##### Contains the following experimental packages - -- `opentelemetry-api` 1.x.y-b0 - - Contains the EXPERIMENTAL API for metrics plus other unstable features. There are no stability guarantees. -- `opentelemetry-sdk` 1.x.y-b0 - - Contains the EXPERIMENTAL SDK for metrics plus other unstable features. There are no stability guarantees. - #### V1.15.0 Release (with metrics) - `opentelemetry-api` 1.15.0 @@ -67,9 +60,9 @@ Purely for illustration purposes, not intended to represent actual releases: - `opentelemetry-sdk` 1.15.0 - Contains SDK components for tracing, baggage, propagators, context and metrics -##### Contains the following experimental packages +##### Contains the following pre-release packages -- `opentelemetry-api` 1.x.y-b0 - - Contains the EXPERIMENTAL API for logging plus other unstable features. There are no stability guarantees. -- `opentelemetry-sdk` 1.x.y-b0 - - Contains the EXPERIMENTAL SDK for logging plus other unstable features. There are no stability guarantees. +- `opentelemetry-api` 1.x.yrc1 + - Contains the experimental public API for logging plus other unstable features. There are no stability guarantees. +- `opentelemetry-sdk` 1.x.yrc1 + - Contains the experimental public SDK for logging plus other unstable features. There are no stability guarantees. From a9a96aad8b930a7efdea1ad979aefc173e1710d0 Mon Sep 17 00:00:00 2001 From: Alex Boten Date: Fri, 24 Feb 2023 11:11:05 -0800 Subject: [PATCH 2/2] bugfix: indent not used in MetricsData to_json (#3197) --- CHANGELOG.md | 3 ++- .../src/opentelemetry/sdk/metrics/_internal/point.py | 3 ++- .../tests/metrics/integration_test/test_console_exporter.py | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index e3dd0a0c56a..d43b64cfaf3 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,7 +8,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## Unreleased - PeriodicExportingMetricReader will continue if collection times out ([#3100](https://github.com/open-telemetry/opentelemetry-python/pull/3100)) - +- Fix formatting of ConsoleMetricExporter. + ([#3197](https://github.com/open-telemetry/opentelemetry-python/pull/3197)) ## Version 1.16.0/0.37b0 (2023-02-17) - Change ``__all__`` to be statically defined. diff --git a/opentelemetry-sdk/src/opentelemetry/sdk/metrics/_internal/point.py b/opentelemetry-sdk/src/opentelemetry/sdk/metrics/_internal/point.py index b4d813accaf..410c7754d88 100644 --- a/opentelemetry-sdk/src/opentelemetry/sdk/metrics/_internal/point.py +++ b/opentelemetry-sdk/src/opentelemetry/sdk/metrics/_internal/point.py @@ -211,5 +211,6 @@ def to_json(self, indent=4) -> str: loads(resource_metrics.to_json(indent=indent)) for resource_metrics in self.resource_metrics ] - } + }, + indent=indent, ) diff --git a/opentelemetry-sdk/tests/metrics/integration_test/test_console_exporter.py b/opentelemetry-sdk/tests/metrics/integration_test/test_console_exporter.py index 59f026661c5..60c4227c3b2 100644 --- a/opentelemetry-sdk/tests/metrics/integration_test/test_console_exporter.py +++ b/opentelemetry-sdk/tests/metrics/integration_test/test_console_exporter.py @@ -49,7 +49,7 @@ def test_console_exporter(self): provider.shutdown() output.seek(0) - result_0 = loads(output.readlines()[0]) + result_0 = loads("".join(output.readlines())) self.assertGreater(len(result_0), 0)