Skip to content

Commit

Permalink
Merge branch 'explicit-datasets' into inventory-datasets
Browse files Browse the repository at this point in the history
  • Loading branch information
smklein committed Aug 28, 2024
2 parents b9d3dcc + 474ec13 commit 8c52f4b
Show file tree
Hide file tree
Showing 121 changed files with 11,804 additions and 8,612 deletions.
234 changes: 175 additions & 59 deletions Cargo.lock

Large diffs are not rendered by default.

8 changes: 4 additions & 4 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -282,13 +282,12 @@ api_identity = { path = "api_identity" }
approx = "0.5.1"
assert_matches = "1.5.0"
assert_cmd = "2.0.16"
async-bb8-diesel = { git = "https://github.com/oxidecomputer/async-bb8-diesel", rev = "ed7ab5ef0513ba303d33efd41d3e9e381169d59b" }
async-bb8-diesel = "0.2"
async-trait = "0.1.81"
atomicwrites = "0.4.3"
authz-macros = { path = "nexus/authz-macros" }
backoff = { version = "0.4.0", features = [ "tokio" ] }
base64 = "0.22.1"
bb8 = "0.8.5"
bcs = "0.1.6"
bincode = "1.3.3"
bootstore = { path = "bootstore" }
Expand Down Expand Up @@ -400,7 +399,7 @@ ipnetwork = { version = "0.20", features = ["schemars"] }
ispf = { git = "https://github.com/oxidecomputer/ispf" }
key-manager = { path = "key-manager" }
kstat-rs = "0.2.4"
libc = "0.2.156"
libc = "0.2.158"
libfalcon = { git = "https://github.com/oxidecomputer/falcon", rev = "e69694a1f7cc9fe31fab27f321017280531fb5f7" }
libnvme = { git = "https://github.com/oxidecomputer/libnvme", rev = "dd5bb221d327a1bc9287961718c3c10d6bd37da0" }
linear-map = "1.2.0"
Expand Down Expand Up @@ -497,6 +496,7 @@ bhyve_api = { git = "https://github.com/oxidecomputer/propolis", rev = "24a74d0c
propolis-client = { git = "https://github.com/oxidecomputer/propolis", rev = "24a74d0c76b6a63961ecef76acb1516b6e66c5c9" }
propolis-mock-server = { git = "https://github.com/oxidecomputer/propolis", rev = "24a74d0c76b6a63961ecef76acb1516b6e66c5c9" }
proptest = "1.5.0"
qorb = { git = "https://github.com/oxidecomputer/qorb", branch = "master" }
quote = "1.0"
rand = "0.8.5"
rand_core = "0.6.4"
Expand Down Expand Up @@ -580,7 +580,7 @@ textwrap = "0.16.1"
test-strategy = "0.3.1"
thiserror = "1.0"
tofino = { git = "https://github.com/oxidecomputer/tofino", branch = "main" }
tokio = "1.38.1"
tokio = "1.39.3"
tokio-postgres = { version = "0.7", features = [ "with-chrono-0_4", "with-uuid-1" ] }
tokio-stream = "0.1.15"
tokio-tungstenite = "0.20"
Expand Down
9 changes: 3 additions & 6 deletions clients/nexus-client/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -131,14 +131,11 @@ impl From<omicron_common::api::internal::nexus::VmmRuntimeState>
}
}

impl From<omicron_common::api::internal::nexus::SledInstanceState>
for types::SledInstanceState
impl From<omicron_common::api::internal::nexus::SledVmmState>
for types::SledVmmState
{
fn from(
s: omicron_common::api::internal::nexus::SledInstanceState,
) -> Self {
fn from(s: omicron_common::api::internal::nexus::SledVmmState) -> Self {
Self {
propolis_id: s.propolis_id,
vmm_state: s.vmm_state.into(),
migration_in: s.migration_in.map(Into::into),
migration_out: s.migration_out.map(Into::into),
Expand Down
30 changes: 15 additions & 15 deletions clients/sled-agent-client/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
//! Interface for making API requests to a Sled Agent
use async_trait::async_trait;
use omicron_uuid_kinds::PropolisUuid;
use schemars::JsonSchema;
use serde::Deserialize;
use serde::Serialize;
Expand Down Expand Up @@ -163,12 +164,11 @@ impl From<types::VmmRuntimeState>
}
}

impl From<types::SledInstanceState>
for omicron_common::api::internal::nexus::SledInstanceState
impl From<types::SledVmmState>
for omicron_common::api::internal::nexus::SledVmmState
{
fn from(s: types::SledInstanceState) -> Self {
fn from(s: types::SledVmmState) -> Self {
Self {
propolis_id: s.propolis_id,
vmm_state: s.vmm_state.into(),
migration_in: s.migration_in.map(Into::into),
migration_out: s.migration_out.map(Into::into),
Expand Down Expand Up @@ -450,33 +450,33 @@ impl From<types::SledIdentifiers>
/// are bonus endpoints, not generated in the real client.
#[async_trait]
pub trait TestInterfaces {
async fn instance_single_step(&self, id: Uuid);
async fn instance_finish_transition(&self, id: Uuid);
async fn instance_simulate_migration_source(
async fn vmm_single_step(&self, id: PropolisUuid);
async fn vmm_finish_transition(&self, id: PropolisUuid);
async fn vmm_simulate_migration_source(
&self,
id: Uuid,
id: PropolisUuid,
params: SimulateMigrationSource,
);
async fn disk_finish_transition(&self, id: Uuid);
}

#[async_trait]
impl TestInterfaces for Client {
async fn instance_single_step(&self, id: Uuid) {
async fn vmm_single_step(&self, id: PropolisUuid) {
let baseurl = self.baseurl();
let client = self.client();
let url = format!("{}/instances/{}/poke-single-step", baseurl, id);
let url = format!("{}/vmms/{}/poke-single-step", baseurl, id);
client
.post(url)
.send()
.await
.expect("instance_single_step() failed unexpectedly");
}

async fn instance_finish_transition(&self, id: Uuid) {
async fn vmm_finish_transition(&self, id: PropolisUuid) {
let baseurl = self.baseurl();
let client = self.client();
let url = format!("{}/instances/{}/poke", baseurl, id);
let url = format!("{}/vmms/{}/poke", baseurl, id);
client
.post(url)
.send()
Expand All @@ -495,14 +495,14 @@ impl TestInterfaces for Client {
.expect("disk_finish_transition() failed unexpectedly");
}

async fn instance_simulate_migration_source(
async fn vmm_simulate_migration_source(
&self,
id: Uuid,
id: PropolisUuid,
params: SimulateMigrationSource,
) {
let baseurl = self.baseurl();
let client = self.client();
let url = format!("{baseurl}/instances/{id}/sim-migration-source");
let url = format!("{baseurl}/vmms/{id}/sim-migration-source");
client
.post(url)
.json(&params)
Expand Down
2 changes: 1 addition & 1 deletion common/src/api/external/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2382,7 +2382,7 @@ pub struct SwitchPortLinkConfig {

/// The link-layer discovery protocol service configuration id for this
/// link.
pub lldp_link_config_id: Uuid,
pub lldp_link_config_id: Option<Uuid>,

/// The name of this link.
pub link_name: String,
Expand Down
10 changes: 3 additions & 7 deletions common/src/api/internal/nexus.rs
Original file line number Diff line number Diff line change
Expand Up @@ -113,13 +113,9 @@ pub struct VmmRuntimeState {
pub time_updated: DateTime<Utc>,
}

/// A wrapper type containing a sled's total knowledge of the state of a
/// specific VMM and the instance it incarnates.
/// A wrapper type containing a sled's total knowledge of the state of a VMM.
#[derive(Clone, Debug, Deserialize, Serialize, JsonSchema)]
pub struct SledInstanceState {
/// The ID of the VMM whose state is being reported.
pub propolis_id: PropolisUuid,

pub struct SledVmmState {
/// The most recent state of the sled's VMM process.
pub vmm_state: VmmRuntimeState,

Expand All @@ -142,7 +138,7 @@ impl Migrations<'_> {
}
}

impl SledInstanceState {
impl SledVmmState {
pub fn migrations(&self) -> Migrations<'_> {
Migrations {
migration_in: self.migration_in.as_ref(),
Expand Down
89 changes: 87 additions & 2 deletions common/src/disk.rs
Original file line number Diff line number Diff line change
Expand Up @@ -135,6 +135,91 @@ impl DatasetName {
}
}

#[derive(
Copy,
Clone,
Debug,
Deserialize,
Serialize,
JsonSchema,
PartialEq,
Eq,
Hash,
PartialOrd,
Ord,
)]
pub struct GzipLevel(u8);

// Fastest compression level
const GZIP_LEVEL_MIN: u8 = 1;

// Best compression ratio
const GZIP_LEVEL_MAX: u8 = 9;

impl GzipLevel {
pub const fn new<const N: u8>() -> Self {
assert!(N >= GZIP_LEVEL_MIN, "Compression level too small");
assert!(N <= GZIP_LEVEL_MAX, "Compression level too large");
Self(N)
}
}

#[derive(
Copy,
Clone,
Debug,
Default,
Deserialize,
Serialize,
JsonSchema,
PartialEq,
Eq,
Hash,
PartialOrd,
Ord,
)]
#[serde(tag = "type", rename_all = "snake_case")]
pub enum CompressionAlgorithm {
// Selects a default compression algorithm. This is dependent on both the
// zpool and OS version.
On,

// Disables compression.
#[default]
Off,

// Selects the default Gzip compression level.
//
// According to the ZFS docs, this is "gzip-6", but that's a default value,
// which may change with OS updates.
Gzip,

GzipN {
level: GzipLevel,
},
Lz4,
Lzjb,
Zle,
}

impl fmt::Display for CompressionAlgorithm {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
use CompressionAlgorithm::*;
let s = match self {
On => "on",
Off => "off",
Gzip => "gzip",
GzipN { level } => {
return write!(f, "gzip-{}", level.0);
}
Lz4 => "lz4",
Lzjb => "lzjb",
Zle => "zle",
};
write!(f, "{}", s)
}
}

/// Configuration information necessary to request a single dataset
#[derive(
Clone,
Expand All @@ -155,8 +240,8 @@ pub struct DatasetConfig {
/// The dataset's name
pub name: DatasetName,

/// The compression mode to be supplied, if any
pub compression: Option<String>,
/// The compression mode to be used by the dataset
pub compression: CompressionAlgorithm,

/// The upper bound on the amount of storage used by this dataset
pub quota: Option<ByteCount>,
Expand Down
24 changes: 24 additions & 0 deletions common/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -118,3 +118,27 @@ where
async fn never_bail() -> Result<bool, Error> {
Ok(false)
}

/// A wrapper struct that does nothing other than elide the inner value from
/// [`std::fmt::Debug`] output.
///
/// We define this within Omicron instead of using one of the many available
/// crates that do the same thing because it's trivial to do so, and we want the
/// flexibility to add traits to this type without needing to wait on upstream
/// to add an optional dependency.
///
/// If you want to use this for secrets, consider that it might not do
/// everything you expect (it does not zeroize memory on drop, nor get in the
/// way of you removing the inner value from this wrapper struct).
#[derive(
Clone, Copy, serde::Deserialize, serde::Serialize, schemars::JsonSchema,
)]
#[repr(transparent)]
#[serde(transparent)]
pub struct NoDebug<T>(pub T);

impl<T> std::fmt::Debug for NoDebug<T> {
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
write!(f, "..")
}
}
13 changes: 7 additions & 6 deletions dev-tools/omdb/src/bin/omdb/db.rs
Original file line number Diff line number Diff line change
Expand Up @@ -246,7 +246,8 @@ impl DbUrlOptions {
eprintln!("note: using database URL {}", &db_url);

let db_config = db::Config { url: db_url.clone() };
let pool = Arc::new(db::Pool::new(&log.clone(), &db_config));
let pool =
Arc::new(db::Pool::new_single_host(&log.clone(), &db_config));

// Being a dev tool, we want to try this operation even if the schema
// doesn't match what we expect. So we use `DataStore::new_unchecked()`
Expand Down Expand Up @@ -4224,7 +4225,7 @@ async fn cmd_db_inventory(
}

async fn cmd_db_inventory_baseboard_ids(
conn: &DataStoreConnection<'_>,
conn: &DataStoreConnection,
limit: NonZeroU32,
) -> Result<(), anyhow::Error> {
#[derive(Tabled)]
Expand Down Expand Up @@ -4261,7 +4262,7 @@ async fn cmd_db_inventory_baseboard_ids(
}

async fn cmd_db_inventory_cabooses(
conn: &DataStoreConnection<'_>,
conn: &DataStoreConnection,
limit: NonZeroU32,
) -> Result<(), anyhow::Error> {
#[derive(Tabled)]
Expand Down Expand Up @@ -4302,7 +4303,7 @@ async fn cmd_db_inventory_cabooses(
}

async fn cmd_db_inventory_physical_disks(
conn: &DataStoreConnection<'_>,
conn: &DataStoreConnection,
limit: NonZeroU32,
args: InvPhysicalDisksArgs,
) -> Result<(), anyhow::Error> {
Expand Down Expand Up @@ -4359,7 +4360,7 @@ async fn cmd_db_inventory_physical_disks(
}

async fn cmd_db_inventory_rot_pages(
conn: &DataStoreConnection<'_>,
conn: &DataStoreConnection,
limit: NonZeroU32,
) -> Result<(), anyhow::Error> {
#[derive(Tabled)]
Expand Down Expand Up @@ -4394,7 +4395,7 @@ async fn cmd_db_inventory_rot_pages(
}

async fn cmd_db_inventory_collections_list(
conn: &DataStoreConnection<'_>,
conn: &DataStoreConnection,
limit: NonZeroU32,
) -> Result<(), anyhow::Error> {
#[derive(Tabled)]
Expand Down
Loading

0 comments on commit 8c52f4b

Please sign in to comment.