Skip to content

Commit 87498fd

Browse files
committed
Simplify bootstrap and generate code
- We now automatically generate bootstrap_gen.py file from the list of instrumentations present in the source tree. - Bootstrap command now uses consumes this auto-generated list instead of keeping it's own local copy. - We no longer uninstall packages before installing them as instrumentation package no longer specify libraries as dependencies so the edge cases are no longer there. - We no longer try to install an incompatible version or force upgrade/downgrade an installed version. This used to leave systems in broken states which should happen no more.
1 parent 4a8b32b commit 87498fd

File tree

47 files changed

+1317
-214
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

47 files changed

+1317
-214
lines changed

.github/workflows/test.yml

+5-1
Original file line numberDiff line numberDiff line change
@@ -76,7 +76,7 @@ jobs:
7676
strategy:
7777
fail-fast: false
7878
matrix:
79-
tox-environment: [ "docker-tests", "lint", "docs" ]
79+
tox-environment: [ "docker-tests", "lint", "docs", "generate" ]
8080
name: ${{ matrix.tox-environment }}
8181
runs-on: ubuntu-latest
8282
steps:
@@ -102,3 +102,7 @@ jobs:
102102
key: v2-misc-tox-cache-${{ matrix.tox-environment }}-${{ hashFiles('tox.ini', 'dev-requirements.txt', 'docs-requirements.txt') }}
103103
- name: run tox
104104
run: tox -e ${{ matrix.tox-environment }}
105+
- name: Ensure generated code is up to date
106+
if: matrix.tox-environment == 'generate'
107+
run: >-
108+
git diff --exit-code || (echo 'Generated code is out of date, please run "tox -e generate" and commit the changes in this PR.' && exit 1)

.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@
88
*.egg
99
*.egg-info
1010
dist
11+
dist-info
1112
build
1213
eggs
1314
parts

CHANGELOG.md

+4
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
77
## [Unreleased](https://github.com/open-telemetry/opentelemetry-python/compare/v1.2.0-0.21b0...HEAD)
88

99
### Changed
10+
- `opentelemetry-bootstrap` not longer forcibly removes and re-installs libraries and their instrumentations.
11+
This means running bootstrap will not auto-upgrade existing dependencies and as a result not cause dependency
12+
conflicts.
13+
([#514](https://github.com/open-telemetry/opentelemetry-python-contrib/pull/514))
1014
- `opentelemetry-instrumentation-asgi` Set the response status code on the server span
1115
([#478](https://github.com/open-telemetry/opentelemetry-python-contrib/pull/478))
1216
- `opentelemetry-instrumentation-tornado` Fixed cases where description was used with non-

CONTRIBUTING.md

+1-1
Original file line numberDiff line numberDiff line change
@@ -170,7 +170,7 @@ Below is a checklist of things to be mindful of when implementing a new instrume
170170
- Extends from [BaseInstrumentor](https://github.com/open-telemetry/opentelemetry-python-contrib/blob/main/opentelemetry-instrumentation/src/opentelemetry/instrumentation/instrumentor.py#L26)
171171
- Supports auto-instrumentation
172172
- Add an entry point (ex. https://github.com/open-telemetry/opentelemetry-python-contrib/blob/main/instrumentation/opentelemetry-instrumentation-requests/setup.cfg#L56)
173-
- Add instrumentation package to `bootstrap.py` (https://github.com/open-telemetry/opentelemetry-python-contrib/blob/main/opentelemetry-instrumentation/src/opentelemetry/instrumentation/bootstrap.py#L37)
173+
- Run `python scripts/setup.py` followed by `python scripts/generate_instrumentation_bootstrap.py` after adding a new instrumentation package.
174174
- Functionality that is common amongst other instrumentation and can be abstracted [here](https://github.com/open-telemetry/opentelemetry-python-contrib/tree/main/opentelemetry-instrumentation/src/opentelemetry/instrumentation)
175175
- Request/response [hooks](https://github.com/open-telemetry/opentelemetry-python-contrib/issues/408) for http instrumentations
176176
- `suppress_instrumentation` functionality

dev-requirements.txt

+1-2
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,6 @@
1+
-r gen-requirements.txt
12
pylint~=2.6
23
flake8~=3.7
3-
isort~=5.6
4-
black>=19.3b0,==19.*
54
httpretty~=1.0
65
mypy==0.790
76
sphinx

gen-requirements.txt

+4
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,4 @@
1+
astor~=0.8.1
2+
isort~=5.6
3+
black>=19.3b0,==19.*
4+
jinja2~=2.7

instrumentation/opentelemetry-instrumentation-aiohttp-client/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -66,6 +68,32 @@
6668

6769
extras_require["test"] = test_deps
6870

71+
72+
class JSONMetadataCommand(distutils.cmd.Command):
73+
74+
description = (
75+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
76+
"auto-generate code in other places",
77+
)
78+
user_options = []
79+
80+
def initialize_options(self):
81+
pass
82+
83+
def finalize_options(self):
84+
pass
85+
86+
def run(self):
87+
metadata = {
88+
"name": config["metadata"]["name"],
89+
"version": PACKAGE_INFO["__version__"],
90+
"instruments": PACKAGE_INFO["_instruments"],
91+
}
92+
print(json.dumps(metadata))
93+
94+
6995
setuptools.setup(
70-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
96+
cmdclass={"meta": JSONMetadataCommand},
97+
version=PACKAGE_INFO["__version__"],
98+
extras_require=extras_require,
7199
)

instrumentation/opentelemetry-instrumentation-aiopg/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -56,6 +58,32 @@
5658

5759
extras_require["test"] = test_deps
5860

61+
62+
class JSONMetadataCommand(distutils.cmd.Command):
63+
64+
description = (
65+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
66+
"auto-generate code in other places",
67+
)
68+
user_options = []
69+
70+
def initialize_options(self):
71+
pass
72+
73+
def finalize_options(self):
74+
pass
75+
76+
def run(self):
77+
metadata = {
78+
"name": config["metadata"]["name"],
79+
"version": PACKAGE_INFO["__version__"],
80+
"instruments": PACKAGE_INFO["_instruments"],
81+
}
82+
print(json.dumps(metadata))
83+
84+
5985
setuptools.setup(
60-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
86+
cmdclass={"meta": JSONMetadataCommand},
87+
version=PACKAGE_INFO["__version__"],
88+
extras_require=extras_require,
6189
)

instrumentation/opentelemetry-instrumentation-asgi/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -56,6 +58,32 @@
5658

5759
extras_require["test"] = test_deps
5860

61+
62+
class JSONMetadataCommand(distutils.cmd.Command):
63+
64+
description = (
65+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
66+
"auto-generate code in other places",
67+
)
68+
user_options = []
69+
70+
def initialize_options(self):
71+
pass
72+
73+
def finalize_options(self):
74+
pass
75+
76+
def run(self):
77+
metadata = {
78+
"name": config["metadata"]["name"],
79+
"version": PACKAGE_INFO["__version__"],
80+
"instruments": PACKAGE_INFO["_instruments"],
81+
}
82+
print(json.dumps(metadata))
83+
84+
5985
setuptools.setup(
60-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
86+
cmdclass={"meta": JSONMetadataCommand},
87+
version=PACKAGE_INFO["__version__"],
88+
extras_require=extras_require,
6189
)

instrumentation/opentelemetry-instrumentation-asyncpg/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -66,6 +68,32 @@
6668

6769
extras_require["test"] = test_deps
6870

71+
72+
class JSONMetadataCommand(distutils.cmd.Command):
73+
74+
description = (
75+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
76+
"auto-generate code in other places",
77+
)
78+
user_options = []
79+
80+
def initialize_options(self):
81+
pass
82+
83+
def finalize_options(self):
84+
pass
85+
86+
def run(self):
87+
metadata = {
88+
"name": config["metadata"]["name"],
89+
"version": PACKAGE_INFO["__version__"],
90+
"instruments": PACKAGE_INFO["_instruments"],
91+
}
92+
print(json.dumps(metadata))
93+
94+
6995
setuptools.setup(
70-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
96+
cmdclass={"meta": JSONMetadataCommand},
97+
version=PACKAGE_INFO["__version__"],
98+
extras_require=extras_require,
7199
)

instrumentation/opentelemetry-instrumentation-boto/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -56,6 +58,32 @@
5658

5759
extras_require["test"] = test_deps
5860

61+
62+
class JSONMetadataCommand(distutils.cmd.Command):
63+
64+
description = (
65+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
66+
"auto-generate code in other places",
67+
)
68+
user_options = []
69+
70+
def initialize_options(self):
71+
pass
72+
73+
def finalize_options(self):
74+
pass
75+
76+
def run(self):
77+
metadata = {
78+
"name": config["metadata"]["name"],
79+
"version": PACKAGE_INFO["__version__"],
80+
"instruments": PACKAGE_INFO["_instruments"],
81+
}
82+
print(json.dumps(metadata))
83+
84+
5985
setuptools.setup(
60-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
86+
cmdclass={"meta": JSONMetadataCommand},
87+
version=PACKAGE_INFO["__version__"],
88+
extras_require=extras_require,
6189
)

instrumentation/opentelemetry-instrumentation-botocore/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -66,6 +68,32 @@
6668

6769
extras_require["test"] = test_deps
6870

71+
72+
class JSONMetadataCommand(distutils.cmd.Command):
73+
74+
description = (
75+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
76+
"auto-generate code in other places",
77+
)
78+
user_options = []
79+
80+
def initialize_options(self):
81+
pass
82+
83+
def finalize_options(self):
84+
pass
85+
86+
def run(self):
87+
metadata = {
88+
"name": config["metadata"]["name"],
89+
"version": PACKAGE_INFO["__version__"],
90+
"instruments": PACKAGE_INFO["_instruments"],
91+
}
92+
print(json.dumps(metadata))
93+
94+
6995
setuptools.setup(
70-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
96+
cmdclass={"meta": JSONMetadataCommand},
97+
version=PACKAGE_INFO["__version__"],
98+
extras_require=extras_require,
7199
)

instrumentation/opentelemetry-instrumentation-celery/setup.py

+29-1
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@
1818

1919

2020
import os
21+
import distutils.cmd
22+
import json
2123
from configparser import ConfigParser
2224

2325
import setuptools
@@ -56,6 +58,32 @@
5658

5759
extras_require["test"] = test_deps
5860

61+
62+
class JSONMetadataCommand(distutils.cmd.Command):
63+
64+
description = (
65+
"print out package metadata as JSON. This is used by OpenTelemetry dev scripts to ",
66+
"auto-generate code in other places",
67+
)
68+
user_options = []
69+
70+
def initialize_options(self):
71+
pass
72+
73+
def finalize_options(self):
74+
pass
75+
76+
def run(self):
77+
metadata = {
78+
"name": config["metadata"]["name"],
79+
"version": PACKAGE_INFO["__version__"],
80+
"instruments": PACKAGE_INFO["_instruments"],
81+
}
82+
print(json.dumps(metadata))
83+
84+
5985
setuptools.setup(
60-
version=PACKAGE_INFO["__version__"], extras_require=extras_require
86+
cmdclass={"meta": JSONMetadataCommand},
87+
version=PACKAGE_INFO["__version__"],
88+
extras_require=extras_require,
6189
)

0 commit comments

Comments
 (0)