Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

v2.37.0 proposal #3268

Merged
merged 42 commits into from
Jun 23, 2023
Merged

v2.37.0 proposal #3268

merged 42 commits into from
Jun 23, 2023

Conversation

nsavoire
Copy link
Collaborator

@nsavoire nsavoire commented Jun 21, 2023

Features

Improvements

Bug Fixes

rochdev and others added 26 commits June 21, 2023 10:27
* add migration guide for 3.x to 4.x

* Update MIGRATING.md

Co-authored-by: Juan Antonio Fernández de Alba <[email protected]>

* Update MIGRATING.md

Co-authored-by: Juan Antonio Fernández de Alba <[email protected]>

* Update README.md

Co-authored-by: Ugaitz Urien <[email protected]>

---------

Co-authored-by: Juan Antonio Fernández de Alba <[email protected]>
Co-authored-by: Ugaitz Urien <[email protected]>
* update readme to include v4

* use version module instead of semver to match library version
* Unvalidated redirect analyzer

* Ignore tainteds from Referer header
)

* Add _dd.iast.enabled=1 in out of request vulnerabilities tags

* Rename constants.js to tags.js
* add v0 naming to tedious (mssql)
* add v1 naming to tedious (mssql)
* switch to a mostly working test sqlserver

  The standard mssql server image does not work on ARM [1].

  Instead, we use `azure-sql-edge` [2], which provides a sufficient subset
  of mssql server API to test most of our integration. 

  Unfortunately, this image does not support stored procedures [3], so
  tests related to these will still fail locally.

  [1] microsoft/mssql-docker#668
  [2] https://hub.docker.com/_/microsoft-azure-sql-edge
  [3] https://learn.microsoft.com/en-us/azure/azure-sql-edge/features#unsupported-features
* add v0 naming to mysql integrations
* add v1 to mysql integrations
* add tests on v1 for mysql databases

---------

Co-authored-by: Thomas Hunter II <[email protected]>
* Taint cookies and headers

* Bump minimum node version for v4 on cookie plugin test

* Add test with latest node version for cookie plugin test

* Provide iastContext from index when tainting headers

* Add test for cookie tainting in taint tracking plugin

* Remove iast transaction after taint tracking plugin tests to avoid hiting setMaxTransactions in tests

* Add test for taintObject with taintingKeys flag

* Address header tainting test for keys shorter than 10 chars

* Upgrade native-iast-taint-tracking to v1.5.0

* Rewrite expect in taint tracking plugin test

* Fix tag requiring in IAST index

---------

Co-authored-by: Thomas Hunter II <[email protected]>
* Add sources tests

* styles
* appsec-iast benchmark tests

* writing fixes

Co-authored-by: simon-id <[email protected]>

* small fixes

---------

Co-authored-by: simon-id <[email protected]>
* Reduce request per iteration in IAST benchmarks

* Reduce a bit more

* 30 iterations 200 requests
@github-actions
Copy link

github-actions bot commented Jun 21, 2023

Overall package size

Self size: 4.4 MB
Deduped: 71.1 MB
No deduping: 71.15 MB

Dependency sizes

name version self size total size
@datadog/pprof 2.2.3 14.25 MB 15.13 MB
@datadog/native-iast-taint-tracking 1.5.0 14.86 MB 14.86 MB
@datadog/native-appsec 3.2.0 13.38 MB 13.39 MB
@datadog/native-metrics 1.6.0 7.88 MB 7.89 MB
protobufjs 7.2.3 2.77 MB 6.65 MB
@types/node 18.11.19 3.58 MB 3.58 MB
@datadog/native-iast-rewriter 2.0.1 2.09 MB 2.1 MB
@opentelemetry/core 1.3.1 784.66 kB 1.37 MB
@opentelemetry/api 1.4.1 780.32 kB 780.32 kB
opentracing 0.14.7 194.81 kB 194.81 kB
lru-cache 7.18.3 133.92 kB 133.92 kB
semver 7.5.3 93.39 kB 123.79 kB
@datadog/sketches-js 2.1.0 109.9 kB 109.9 kB
lodash.sortby 4.7.0 75.76 kB 75.76 kB
ipaddr.js 2.0.1 59.52 kB 59.52 kB
ignore 5.2.4 51.22 kB 51.22 kB
import-in-the-middle 1.3.5 34.34 kB 38.81 kB
istanbul-lib-coverage 3.2.0 29.34 kB 29.34 kB
retry 0.10.1 27.44 kB 27.44 kB
lodash.uniq 4.5.0 25.01 kB 25.01 kB
limiter 1.1.5 23.17 kB 23.17 kB
lodash.kebabcase 4.1.1 17.75 kB 17.75 kB
node-abort-controller 3.1.1 16.89 kB 16.89 kB
lodash.pick 4.4.0 16.33 kB 16.33 kB
crypto-randomuuid 1.0.0 11.18 kB 11.18 kB
diagnostics_channel 1.1.0 7.07 kB 7.07 kB
path-to-regexp 0.1.7 6.78 kB 6.78 kB
koalas 1.0.2 6.47 kB 6.47 kB
methods 1.1.2 5.29 kB 5.29 kB
module-details-from-path 1.0.3 4.47 kB 4.47 kB

🤖 This report was automatically generated by heaviest-objects-in-the-universe

@codecov
Copy link

codecov bot commented Jun 21, 2023

Codecov Report

Merging #3268 (79e63a9) into v2.x (fbc2899) will decrease coverage by 7.17%.
The diff coverage is 0.00%.

@@            Coverage Diff             @@
##             v2.x    #3268      +/-   ##
==========================================
- Coverage   93.51%   86.34%   -7.17%     
==========================================
  Files         222      196      -26     
  Lines        8829     7698    -1131     
  Branches        0       33      +33     
==========================================
- Hits         8256     6647    -1609     
- Misses        573     1051     +478     
Impacted Files Coverage Δ
integration-tests/ci-visibility/test/sum.js 69.19% <ø> (ø)
packages/datadog-instrumentations/src/mocha.js 0.00% <0.00%> (-98.64%) ⬇️
packages/datadog-plugin-fastify/src/index.js 100.00% <ø> (ø)

... and 311 files with indirect coverage changes

📣 We’re building smart automated test selection to slash your CI/CD build times. Learn more

@pr-commenter
Copy link

pr-commenter bot commented Jun 21, 2023

Benchmarks

Comparing candidate commit 79e63a9 in PR branch v2.37.0-proposal with baseline commit 4a427a2 in branch v2.x.

Found 0 performance improvements and 40 performance regressions! Performance is the same for 560 metrics, 48 unstable metrics.

scenario:log-without-log-14

  • 🟥 execution_time [+11.777ms; +14.904ms] or [+5.365%; +6.790%]

scenario:plugin-bluebird-with-tracer-14

  • 🟥 cpu_user_time [+15.989ms; +22.015ms] or [+5.425%; +7.470%]
  • 🟥 execution_time [+18.246ms; +20.167ms] or [+5.553%; +6.138%]

scenario:log-without-log-16

  • 🟥 execution_time [+13.132ms; +14.686ms] or [+5.579%; +6.239%]

scenario:log-without-log-18

  • 🟥 cpu_user_time [+25.921ms; +34.495ms] or [+12.275%; +16.335%]
  • 🟥 execution_time [+29.044ms; +31.910ms] or [+11.948%; +13.127%]
  • 🟥 instructions [+44; +44] or [+7.826%; +7.891%]
  • 🟥 max_rss_usage [+3.131KB; +3.284KB] or [+5.611%; +5.885%]

scenario:log-skip-log-18

  • 🟥 cpu_user_time [+11.933ms; +20.984ms] or [+5.591%; +9.832%]
  • 🟥 execution_time [+18.691ms; +19.786ms] or [+7.660%; +8.109%]
  • 🟥 instructions [+43; +44] or [+7.565%; +7.672%]
  • 🟥 max_rss_usage [+3.006KB; +3.219KB] or [+5.390%; +5.772%]

scenario:log-with-error-18

  • 🟥 cpu_user_time [+11.029ms; +19.478ms] or [+5.200%; +9.184%]
  • 🟥 execution_time [+16.861ms; +19.849ms] or [+6.892%; +8.113%]
  • 🟥 instructions [+44; +44] or [+7.606%; +7.709%]
  • 🟥 max_rss_usage [+3.084KB; +3.308KB] or [+5.530%; +5.932%]

scenario:log-with-debug-18

  • 🟥 cpu_user_time [+13.849ms; +21.894ms] or [+6.441%; +10.183%]
  • 🟥 execution_time [+16.190ms; +19.755ms] or [+6.608%; +8.064%]
  • 🟥 instructions [+43; +44] or [+7.551%; +7.658%]
  • 🟥 max_rss_usage [+2.955KB; +3.175KB] or [+5.296%; +5.691%]

scenario:appsec-control-with-attacks-18

  • 🟥 cpu_user_time [+23.231ms; +29.595ms] or [+8.198%; +10.444%]
  • 🟥 execution_time [+28.889ms; +37.540ms] or [+8.355%; +10.857%]
  • 🟥 instructions [+42; +43] or [+5.741%; +5.874%]
  • 🟥 max_rss_usage [+4.007KB; +4.135KB] or [+6.821%; +7.039%]

scenario:appsec-control-18

  • 🟥 cpu_user_time [+20.693ms; +27.257ms] or [+6.759%; +8.903%]
  • 🟥 execution_time [+31.012ms; +40.534ms] or [+8.487%; +11.093%]
  • 🟥 instructions [+42; +43] or [+5.714%; +5.845%]
  • 🟥 max_rss_usage [+3.840KB; +4.009KB] or [+6.526%; +6.813%]

scenario:appsec-appsec-enabled-18

  • 🟥 cpu_user_time [+18.066ms; +25.285ms] or [+5.177%; +7.245%]
  • 🟥 execution_time [+33.523ms; +44.108ms] or [+8.321%; +10.948%]

scenario:appsec-appsec-enabled-with-attacks-18

  • 🟥 cpu_user_time [+22.309ms; +29.819ms] or [+6.126%; +8.188%]
  • 🟥 execution_time [+32.144ms; +41.612ms] or [+7.683%; +9.946%]

scenario:plugin-graphql-with-depth-and-collapse-on-18

  • 🟥 max_rss_usage [+90.223KB; +107.333KB] or [+10.760%; +12.800%]

scenario:plugin-graphql-with-depth-on-max-18

  • 🟥 max_rss_usage [+80.852KB; +108.532KB] or [+9.569%; +12.844%]

scenario:plugin-graphql-with-depth-off-18

  • 🟥 max_rss_usage [+73.470KB; +105.090KB] or [+8.784%; +12.564%]

scenario:plugin-bluebird-with-tracer-18

  • 🟥 execution_time [+18.397ms; +20.657ms] or [+5.631%; +6.323%]
  • 🟥 instructions [+41; +42] or [+5.301%; +5.433%]

scenario:net-with-tracer-18

  • 🟥 cpu_user_time [+15.861ms; +22.384ms] or [+5.466%; +7.714%]
  • 🟥 instructions [+42; +42] or [+5.602%; +5.651%]
  • 🟥 max_rss_usage [+3.035KB; +3.097KB] or [+5.161%; +5.268%]

uurien
uurien previously approved these changes Jun 22, 2023
getPort().then(port => {
agent
.use(traces => {
expect(traces[0][0]).to.have.property('service', 'test-http-client')
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is different between version. Can the change be done in a backward-compatible way to avoid merge conflicts?

Copy link
Collaborator Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I added #3282 to the release which remove the difference between branches.

@nsavoire nsavoire dismissed stale reviews from uurien and juan-fernandez via 68db403 June 22, 2023 23:39
uurien
uurien previously approved these changes Jun 23, 2023
@nsavoire nsavoire requested a review from rochdev June 23, 2023 12:44
rochdev
rochdev previously approved these changes Jun 23, 2023
nsavoire added 2 commits June 23, 2023 14:48
* Add DD_PROFILING_DEBUG_SOURCE_MAPS option

DD_PROFILING_DEBUG_SOURCE_MAPS env variable enables printing of
detailed diagnostics concerning source maps.
Pass logger to profiler module to enable logging.

* Bump profiler version to 2.2.3
@nsavoire nsavoire dismissed stale reviews from rochdev and uurien via 79e63a9 June 23, 2023 12:48
@tlhunter tlhunter merged commit 85a8949 into v2.x Jun 23, 2023
@nsavoire nsavoire deleted the v2.37.0-proposal branch July 17, 2023 08:01
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.