Skip to content

Conversation

santiagorr
Copy link
Contributor

@santiagorr santiagorr commented Mar 5, 2025

Fixes #3267

Changes

Build googletest from the source code along with opentelemetry-cpp, as it is recommended by googletest. Relying on precompiled shared libraries yields to some errors during testing. Using ExternalProject_add() (in favor of alternatives as FetchContent) since googletest is found as a third-party submodule, and it is easier to "integrate" in distros like debian, that ship googletest source code as a package.

I am not able to test how this builds on windows.

For significant contributions please make sure you have completed the following items:

  • CHANGELOG.md updated for non-trivial changes -> I think these are trivial changes, but I can describe them in CHANGELOG.md, if you think that helps.
  • Unit tests have been added -> N/A
  • Changes in public API reviewed -> None

Using the precompiled shared libraries is not recommended, as for
opentelemetry-cpp, some tests end up failing.

Fixes: 3267
It is need to update the git submdule, and move the code to install the
opentelemetry-cpp build dependencies to the ci/setup_ci_environment.sh
script.
@santiagorr santiagorr requested a review from a team as a code owner March 5, 2025 04:12
@netlify
Copy link

netlify bot commented Mar 5, 2025

Deploy Preview for opentelemetry-cpp-api-docs canceled.

Name Link
🔨 Latest commit 78782bd
🔍 Latest deploy log https://app.netlify.com/sites/opentelemetry-cpp-api-docs/deploys/67c7cf38e7225e0008b8a5c2

@santiagorr santiagorr marked this pull request as draft March 5, 2025 04:23
@marcalff
Copy link
Member

@santiagorr This PR is draft, and CI is failing. Are you still working on it ?

@santiagorr
Copy link
Contributor Author

santiagorr commented Mar 26, 2025 via email

endif()
elseif(WIN32)

if(WIN32)
Copy link
Member

@dbarker dbarker Apr 3, 2025

Choose a reason for hiding this comment

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

The general approach looks good - 1) try to find an installed gtest cmake package, 2) build the submodule for gtest if no package is found.

We should try to find the gtest package first on all platforms though - not just windows. The cmake install github workflow has jobs that install gtest with conan on Ubuntu and MacOS and we should ensure those packages are found instead of building the submodule.

@marcalff
Copy link
Member

marcalff commented Apr 7, 2025

A lot has changed in CI recently, please merge with recent code to resolve conflicts.

@marcalff marcalff added the pr:fix-merge-conflicts Please fix merge conflicts for this pr label Apr 7, 2025
run: |
sudo -E ./ci/setup_googletest.sh
sudo -E ./ci/setup_ci_environment.sh
git submodule update --init third_party/googletest
Copy link
Member

Choose a reason for hiding this comment

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

This shouldn't be needed. The submodules are initialized by the checkout action above.

@marcalff
Copy link
Member

A lot has changed in CI recently, please merge with recent code to resolve conflicts.

@santiagorr Thanks for the PR. Are you still working on this ?

@marcalff
Copy link
Member

marcalff commented Jun 8, 2025

PR is still draft after 3 months, CI is failing, and the code is behind the main branch, with merge conflicts.

Closing.

@marcalff marcalff closed this Jun 8, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

pr:fix-merge-conflicts Please fix merge conflicts for this pr

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Build googletest at buildtime, relying on CMake

3 participants