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

[setup] Rewrite Ubuntu install_prereqs from the ground up #22055

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

jwnimmer-tri
Copy link
Collaborator

@jwnimmer-tri jwnimmer-tri commented Oct 17, 2024

TBD


This change is Reviewable

@jwnimmer-tri jwnimmer-tri changed the title [setup] Add --developer flag to install_prereqs [setup] Rewrite Ubuntu install_prereqs from the ground up Nov 4, 2024
@jwnimmer-tri jwnimmer-tri force-pushed the setup-txt-accuracy branch 2 times, most recently from bbf37ee to ef6931b Compare November 4, 2024 17:23
jwnimmer-tri

This comment was marked as resolved.

jwnimmer-tri

This comment was marked as resolved.

The existing from-source setup scripts are deprecated and will be
removed after 2025-07-01:
- setup/ubuntu/install_prereqs.sh
- setup/ubuntu/source_distribution/install_prereqs_user_environment.sh

Instead, users and developers should run setup/install_prereqs (not as
root).

Bug fixes:
- Promote ca-certificates to binary prerequisites. It's required when
  PackageMap downloads https archives (e.g., package://drake_models).

Usability changes:
- Users never run any of our commands under sudo; we'll request sudo if
  and only if we actually need superuser access.
- Fine-tuned log output, with option for --verbose (e.g., in CI).
- Skip unnecessary steps; incremental runs are typically sub-second.

Maintainability changes:
- One single-file program to maintain, instead of an assortment of bash
  scripts and source and exec each other in weird ways.
- Always use files, not heredocs. (The pkg-config etc in a heredoc were
  documented as unwanted when using Drake's Debian packages, but that
  was wrong; we always want those deps even in Debian packages.) All of
  the new entries in our txt files are ported over from heredocs, as is
  the bazelisk metadata.
- Flavors are now a linear stack, not pick-and-choose hodgepodge. This
  substantially reduces our testing / verification burden. Filenames of
  txt files now exactly match the flavor names.
- Smoother control flow which should pave the way to supporting more
  kinds of platforms beyond Ubuntu. Adding more and better kinds of
  error handling or reporting will be easier now (vs bash).

Website changes:
- Major updates to from_source that explain how to install from CMake.
- Rework the Bazel introductory text to be focused on developers only.
Copy link
Collaborator Author

@jwnimmer-tri jwnimmer-tri left a comment

Choose a reason for hiding this comment

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

Reviewed 1 of 8 files at r9, all commit messages.
Reviewable status: 1 unresolved discussion, needs platform reviewer assigned, needs at least two assigned reviewers, missing label for release notes


a discussion (no related file):
Working

Document the new solver flags in bazel.md.

Copy link
Contributor

@mwoehlke-kitware mwoehlke-kitware left a comment

Choose a reason for hiding this comment

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

Reviewable status: 3 unresolved discussions, needs platform reviewer assigned, needs at least two assigned reviewers, missing label for release notes (waiting on @jwnimmer-tri)


setup/install_prereqs line 1 at r9 (raw file):

#!/bin/bash

Huh? This doesn't look like bash script; did you mean #!/usr/bin/env python3?


setup/ubuntu/packages-jammy-binary.txt line 1 at r9 (raw file):

build-essential

You know, probably not in this pass, but eventually, I'd be very tempted to turn these into a pyproject.toml style single file, e.g.:

[requirements]
build = [
  "cmake",
  ...
]
test = [
  "kcov; dist == 'jammy'",
   ...
]

Or maybe YAML:

requirements:
  build:
    - cmake
    - ...
  test:
    - kcov; dist == 'jammy'
    - ...

Copy link
Collaborator Author

@jwnimmer-tri jwnimmer-tri left a comment

Choose a reason for hiding this comment

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

Reviewable status: 3 unresolved discussions, needs platform reviewer assigned, needs at least two assigned reviewers, missing label for release notes


setup/install_prereqs line 1 at r9 (raw file):

Previously, mwoehlke-kitware (Matthew Woehlke) wrote…

Huh? This doesn't look like bash script; did you mean #!/usr/bin/env python3?

See the first comment paragraph immediate below.


setup/ubuntu/packages-jammy-binary.txt line 1 at r9 (raw file):

Previously, mwoehlke-kitware (Matthew Woehlke) wrote…

You know, probably not in this pass, but eventually, I'd be very tempted to turn these into a pyproject.toml style single file, e.g.:

[requirements]
build = [
  "cmake",
  ...
]
test = [
  "kcov; dist == 'jammy'",
   ...
]

Or maybe YAML:

requirements:
  build:
    - cmake
    - ...
  test:
    - kcov; dist == 'jammy'
    - ...

It will be simplest if it's something we can parse using only the CPython 3.9 stdlib. If not, then we first need some other data file to bootstrap whatever parsing library we need.

Copy link
Contributor

@mwoehlke-kitware mwoehlke-kitware left a comment

Choose a reason for hiding this comment

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

Reviewable status: 1 unresolved discussion, needs platform reviewer assigned, needs at least two assigned reviewers, missing label for release notes (waiting on @jwnimmer-tri)


setup/install_prereqs line 1 at r9 (raw file):

Previously, jwnimmer-tri (Jeremy Nimmer) wrote…

See the first comment paragraph immediate below.

Oh, my, that's... sneaky. Is it really so terrible to have a separate .py?


setup/ubuntu/packages-jammy-binary.txt line 1 at r9 (raw file):

Previously, jwnimmer-tri (Jeremy Nimmer) wrote…

It will be simplest if it's something we can parse using only the CPython 3.9 stdlib. If not, then we first need some other data file to bootstrap whatever parsing library we need.

Point, or we could declare "our own" format that's pretty dumb, or maybe use JSON. I was thinking TOML went back further than it does, though; I see it's only in 3.11. 🙁 In any case, as I said, not something to muck with now.

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.

2 participants