Skip to content

Commit

Permalink
[test visibility] Report logical CPU count (#4709)
Browse files Browse the repository at this point in the history
  • Loading branch information
juan-fernandez authored Sep 20, 2024
1 parent 10ac75c commit 1213484
Show file tree
Hide file tree
Showing 8 changed files with 29 additions and 4 deletions.
4 changes: 4 additions & 0 deletions integration-tests/cucumber/cucumber.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -38,6 +38,7 @@ const {
TEST_SESSION_NAME,
TEST_LEVEL_EVENT_TYPES
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')

const isOldNode = semver.satisfies(process.version, '<=16')
const versions = ['7.0.0', isOldNode ? '9' : 'latest']
Expand Down Expand Up @@ -181,6 +182,7 @@ versions.forEach(version => {
assert.equal(testSessionId.toString(10), testSessionEventContent.test_session_id.toString(10))
assert.isTrue(meta[TEST_SOURCE_FILE].startsWith(featuresPath))
assert.equal(metrics[TEST_SOURCE_START], 1)
assert.exists(metrics[DD_HOST_CPU_COUNT])
})

assert.includeMembers(testEvents.map(test => test.content.resource), [
Expand All @@ -201,6 +203,7 @@ versions.forEach(version => {
testEvents.forEach(({
content: {
meta,
metrics,
test_suite_id: testSuiteId,
test_module_id: testModuleId,
test_session_id: testSessionId
Expand All @@ -218,6 +221,7 @@ versions.forEach(version => {
if (runMode === 'parallel') {
assert.propertyVal(meta, CUCUMBER_IS_PARALLEL, 'true')
}
assert.exists(metrics[DD_HOST_CPU_COUNT])
})

stepEvents.forEach(stepEvent => {
Expand Down
4 changes: 4 additions & 0 deletions integration-tests/cypress/cypress.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ const {
TEST_SESSION_NAME,
TEST_LEVEL_EVENT_TYPES
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')
const { ERROR_MESSAGE } = require('../../packages/dd-trace/src/constants')
const { NODE_MAJOR } = require('../../version')

Expand Down Expand Up @@ -289,6 +290,7 @@ moduleTypes.forEach(({
assert.equal(testSessionId.toString(10), testSessionEventContent.test_session_id.toString(10))
assert.isTrue(meta[TEST_SOURCE_FILE].startsWith('cypress/e2e/'))
assert.equal(metrics[TEST_SOURCE_START], 1)
assert.exists(metrics[DD_HOST_CPU_COUNT])
})

assert.includeMembers(testEvents.map(test => test.content.resource), [
Expand All @@ -306,6 +308,7 @@ moduleTypes.forEach(({
testEvents.forEach(({
content: {
meta,
metrics,
test_suite_id: testSuiteId,
test_module_id: testModuleId,
test_session_id: testSessionId
Expand All @@ -320,6 +323,7 @@ moduleTypes.forEach(({
// Can read DD_TAGS
assert.propertyVal(meta, 'test.customtag', 'customvalue')
assert.propertyVal(meta, 'test.customtag2', 'customvalue2')
assert.exists(metrics[DD_HOST_CPU_COUNT])
})
}, 25000)

Expand Down
3 changes: 3 additions & 0 deletions integration-tests/jest/jest.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ const {
TEST_SESSION_NAME,
TEST_LEVEL_EVENT_TYPES
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')
const { ERROR_MESSAGE } = require('../../packages/dd-trace/src/constants')

const testFile = 'ci-visibility/run-jest.js'
Expand Down Expand Up @@ -169,11 +170,13 @@ describe('jest CommonJS', () => {
// Can read DD_TAGS
assert.propertyVal(testEvent.meta, 'test.customtag', 'customvalue')
assert.propertyVal(testEvent.meta, 'test.customtag2', 'customvalue2')
assert.exists(testEvent.metrics[DD_HOST_CPU_COUNT])
})

suites.forEach(testSuite => {
assert.isTrue(testSuite.meta[TEST_SOURCE_FILE].startsWith('ci-visibility/test/ci-visibility-test'))
assert.equal(testSuite.metrics[TEST_SOURCE_START], 1)
assert.exists(testSuite.metrics[DD_HOST_CPU_COUNT])
})

done()
Expand Down
3 changes: 3 additions & 0 deletions integration-tests/mocha/mocha.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -36,6 +36,7 @@ const {
TEST_SESSION_NAME,
TEST_LEVEL_EVENT_TYPES
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')
const { ERROR_MESSAGE } = require('../../packages/dd-trace/src/constants')

const runTestsWithCoverageCommand = './node_modules/nyc/bin/nyc.js -r=text-summary node ./ci-visibility/run-mocha.js'
Expand Down Expand Up @@ -169,11 +170,13 @@ describe('mocha CommonJS', function () {
// Can read DD_TAGS
assert.propertyVal(testEvent.meta, 'test.customtag', 'customvalue')
assert.propertyVal(testEvent.meta, 'test.customtag2', 'customvalue2')
assert.exists(testEvent.metrics[DD_HOST_CPU_COUNT])
})

suites.forEach(testSuite => {
assert.isTrue(testSuite.meta[TEST_SOURCE_FILE].startsWith('ci-visibility/test/ci-visibility-test'))
assert.equal(testSuite.metrics[TEST_SOURCE_START], 1)
assert.exists(testSuite.metrics[DD_HOST_CPU_COUNT])
})

done()
Expand Down
3 changes: 3 additions & 0 deletions integration-tests/playwright/playwright.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ const {
TEST_SESSION_NAME,
TEST_LEVEL_EVENT_TYPES
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')
const { ERROR_MESSAGE } = require('../../packages/dd-trace/src/constants')

const NUM_RETRIES_EFD = 3
Expand Down Expand Up @@ -118,6 +119,7 @@ versions.forEach((version) => {
}
assert.isTrue(testSuiteEvent.content.meta[TEST_SOURCE_FILE].endsWith('-test.js'))
assert.equal(testSuiteEvent.content.metrics[TEST_SOURCE_START], 1)
assert.exists(testSuiteEvent.content.metrics[DD_HOST_CPU_COUNT])
})

assert.includeMembers(testEvents.map(test => test.content.resource), [
Expand Down Expand Up @@ -145,6 +147,7 @@ versions.forEach((version) => {
assert.propertyVal(testEvent.content.meta, 'test.customtag2', 'customvalue2')
// Adds the browser used
assert.propertyVal(testEvent.content.meta, TEST_CONFIGURATION_BROWSER_NAME, 'chromium')
assert.exists(testEvent.content.metrics[DD_HOST_CPU_COUNT])
})

stepEvents.forEach(stepEvent => {
Expand Down
3 changes: 3 additions & 0 deletions integration-tests/vitest/vitest.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@ const {
TEST_SOURCE_FILE,
TEST_SOURCE_START
} = require('../../packages/dd-trace/src/plugins/util/test')
const { DD_HOST_CPU_COUNT } = require('../../packages/dd-trace/src/plugins/util/env')

const versions = ['1.6.0', 'latest']

Expand Down Expand Up @@ -145,6 +146,7 @@ versions.forEach((version) => {

testEvents.forEach(test => {
assert.equal(test.content.meta[TEST_COMMAND], 'vitest run')
assert.exists(test.content.metrics[DD_HOST_CPU_COUNT])
})

testSuiteEvents.forEach(testSuite => {
Expand All @@ -153,6 +155,7 @@ versions.forEach((version) => {
testSuite.content.meta[TEST_SOURCE_FILE].startsWith('ci-visibility/vitest-tests/test-visibility')
)
assert.equal(testSuite.content.metrics[TEST_SOURCE_START], 1)
assert.exists(testSuite.content.metrics[DD_HOST_CPU_COUNT])
})
// TODO: check error messages
}).then(() => done()).catch(done)
Expand Down
7 changes: 5 additions & 2 deletions packages/dd-trace/src/plugins/util/env.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,16 @@ const OS_VERSION = 'os.version'
const OS_ARCHITECTURE = 'os.architecture'
const RUNTIME_NAME = 'runtime.name'
const RUNTIME_VERSION = 'runtime.version'
const DD_HOST_CPU_COUNT = '_dd.host.vcpu_count'

function getRuntimeAndOSMetadata () {
return {
[RUNTIME_VERSION]: process.version,
[OS_ARCHITECTURE]: process.arch,
[OS_PLATFORM]: process.platform,
[RUNTIME_NAME]: 'node',
[OS_VERSION]: os.release()
[OS_VERSION]: os.release(),
[DD_HOST_CPU_COUNT]: os.cpus().length
}
}

Expand All @@ -22,5 +24,6 @@ module.exports = {
OS_VERSION,
OS_ARCHITECTURE,
RUNTIME_NAME,
RUNTIME_VERSION
RUNTIME_VERSION,
DD_HOST_CPU_COUNT
}
6 changes: 4 additions & 2 deletions packages/dd-trace/test/plugins/util/env.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@ const {
OS_PLATFORM,
OS_VERSION,
RUNTIME_NAME,
RUNTIME_VERSION
RUNTIME_VERSION,
DD_HOST_CPU_COUNT
} = require('../../../src/plugins/util/env')

describe('env', () => {
Expand All @@ -22,7 +23,8 @@ describe('env', () => {
[OS_ARCHITECTURE]: process.arch,
[OS_PLATFORM]: process.platform,
[RUNTIME_NAME]: 'node',
[OS_VERSION]: os.release()
[OS_VERSION]: os.release(),
[DD_HOST_CPU_COUNT]: os.cpus().length
}
)
})
Expand Down

0 comments on commit 1213484

Please sign in to comment.