tree: 988ed5e52ca771b8abe1c88741e285c772c9da7f [path history] [tgz]
  1. bin/
  2. doc/
  3. fidl/
  4. lib/
  5. repositories/
  6. scripts/
  7. testing/
  8. tests/
  9. BUILD.gn
  10. eager_package_config.gni
  11. OWNERS
  12. README.md
src/sys/pkg/README.md

Software Delivery README

Overview

The Software Delivery (SWD) stack is responsible for all updates of runnable software on a Fuchsia device, including system updates and individual package updates.

This document serves as a jumping-off point for the SWD codebase, and a contribution guide.

Before starting, you may wish to read some documentation on Fuchsia software packaging, or the long term SWD goals.

Software Delivery (SWD) Subsystems

Software Delivery Diagram

Major Binaries

Updated: June 2021

SubsystemPurposeLocationLanguage
pkg-cacheCaches downloaded packages in case they are needed again.//src/sys/pkg/bin/pkg-cacheRust
pkg-resolverMain entry point for software delivery stack. Coordinates retrieval and installation of packages.//src/sys/pkg/bin/pkg-resolverRust
omaha-clientChecks for system updates using the Omaha server infrastructure//src/sys/pkg/bin/omaha-clientRust
pkgctlCLI for pkg-resolver//src/sys/pkg/bin/pkgctlRust
pkgfsA filesystem for interacting with packages that are stored on a host.//src/sys/pkg/bin/pkgfs/pkgfsGo
system-ota-testAn end-to-end test of system over the air updates.//src/sys/pkg/tests/system-ota-testsGo
system-update-checkerDoes what it says on the tin, checks for system updates!//src/sys/pkg/bin/system-update-checkerRust
system-updater-committerComponent responsible for committing the update.//src/sys/pkg/bin/system-update-committerRust
system-updaterActually performs system updates.//src/sys/pkg/bin/system-updaterRust

Key Dependencies

Useful Debugging Tools

  • fidlcat: it’s strace, but for every IPC on the system, not just syscalls.
  • zxdb: Fuchsia’s debugger. Similar usage to gdb, and has Unicode support (emoji!). Doesn’t currently work well with golang, but works fine with Rust.
  • Inspect: Opt-in APIs for components to expose aspects of their state. Several portions of the SWD stack implement this, and more to come.
IDEs

VS Code seems to work pretty well. Follow the instructions here, including any language-specific instructions you find relevant; the Rust instructions are a good place to start.

Style Guide

Use the style guide appropriate for the language you’re in. The SWD stack is mostly in Rust and Go, which have strong opinions about style. All commits in those languages should be formatted with rustfmt and gofmt respectively, and most editors/IDEs have a mode in which you can run those commands when you save a file. Do so!

Setup

Fuchsia Setup

Read the Fuchsia Getting Started guide first

Most of the SWD stack is in the base image of fuchsia, so to get a swd stack working with tests, your build configuration is quite simple:

First tests


Tab 1 > fx set core.x64 --with //bundles:tests && fx build && fx serve Tab 2 > fx qemu -kN Tab 3 > fx test pkg-resolver-integration-tests # example of running the pkg-resolver integration tests

For further info on fx workflows: https://fuchsia.dev/fuchsia-src/development/workflows/fx

More general tests

If you’ve successfully run the above, you have a working Fuchsia system with the software delivery stack working.

You can discover more tests with by running fx list-packages on the host.

Common Workflows

Updating a base image to get a new version of pkg-resolver or pkgctl

To update the base of your fuchsia image, you can use fx ota if you’re running on hardware which supports OTA. If you’re running under QEMU, you’ll need to just restart QEMU to get an updated base after a rebuild. Don’t worry, it’s fast.

Pulling down a new version of an external dependency

You’ll need to update that dependency’s vendored repository in //third_party. See the Rust documentation for examples.

Resolve a package and run a contained component

The package resolver is configured by default to resolve fuchsia.com to the local development host. To run a component in a package you’ve built locally, you can run something like fx shell run fuchsia-pkg://fuchsia.com/<package_name>#meta/<component_name>.cmx

FAQs

How do I run a hosted package server?

See the instructions on running a package repository with pm

More information: