Create module for primitive types
This commit is contained in:
parent
bc8e2f46ab
commit
5a4784be56
5 changed files with 62 additions and 51 deletions
|
|
@ -3,6 +3,7 @@
|
||||||
mod args;
|
mod args;
|
||||||
mod config;
|
mod config;
|
||||||
mod id;
|
mod id;
|
||||||
|
mod primitive;
|
||||||
mod server;
|
mod server;
|
||||||
mod shared;
|
mod shared;
|
||||||
mod somehow;
|
mod somehow;
|
||||||
|
|
|
||||||
49
src/primitive.rs
Normal file
49
src/primitive.rs
Normal file
|
|
@ -0,0 +1,49 @@
|
||||||
|
//! Primitive serializable and deserializable types.
|
||||||
|
|
||||||
|
use serde::de;
|
||||||
|
use serde_repr::{Deserialize_repr, Serialize_repr};
|
||||||
|
use time::{format_description::well_known::Rfc3339, OffsetDateTime};
|
||||||
|
|
||||||
|
/// The source of a line of output.
|
||||||
|
#[derive(Clone, Serialize_repr, Deserialize_repr, sqlx::Type)]
|
||||||
|
#[repr(u8)]
|
||||||
|
pub enum Source {
|
||||||
|
Internal = 0,
|
||||||
|
Stdout = 1,
|
||||||
|
Stderr = 2,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The direction a measured value improves in.
|
||||||
|
#[derive(Clone, Serialize_repr, Deserialize_repr, sqlx::Type)]
|
||||||
|
#[repr(i8)]
|
||||||
|
pub enum Direction {
|
||||||
|
LessIsBetter = -1,
|
||||||
|
Neutral = 0,
|
||||||
|
MoreIsBetter = 1,
|
||||||
|
}
|
||||||
|
|
||||||
|
/// A time stamp, usually formatted using RFC3339.
|
||||||
|
#[derive(Clone, Copy, sqlx::Type)]
|
||||||
|
#[sqlx(transparent)]
|
||||||
|
pub struct Timestamp(pub OffsetDateTime);
|
||||||
|
|
||||||
|
impl serde::Serialize for Timestamp {
|
||||||
|
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
|
||||||
|
where
|
||||||
|
S: serde::Serializer,
|
||||||
|
{
|
||||||
|
self.0.format(&Rfc3339).unwrap().serialize(serializer)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'de> serde::Deserialize<'de> for Timestamp {
|
||||||
|
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
|
||||||
|
where
|
||||||
|
D: serde::Deserializer<'de>,
|
||||||
|
{
|
||||||
|
let input: &str = serde::Deserialize::deserialize(deserializer)?;
|
||||||
|
OffsetDateTime::parse(input, &Rfc3339)
|
||||||
|
.map_err(de::Error::custom)
|
||||||
|
.map(Self)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -5,7 +5,8 @@ use time::OffsetDateTime;
|
||||||
use crate::{
|
use crate::{
|
||||||
config::ServerConfig,
|
config::ServerConfig,
|
||||||
id,
|
id,
|
||||||
shared::{BenchMethod, Rfc3339Time, Run, UnfinishedRun, WorkerStatus},
|
primitive::Timestamp,
|
||||||
|
shared::{BenchMethod, Run, UnfinishedRun, WorkerStatus},
|
||||||
};
|
};
|
||||||
|
|
||||||
#[derive(Clone)]
|
#[derive(Clone)]
|
||||||
|
|
@ -84,7 +85,7 @@ impl Workers {
|
||||||
id,
|
id,
|
||||||
hash,
|
hash,
|
||||||
bench_method,
|
bench_method,
|
||||||
start: Rfc3339Time(OffsetDateTime::now_utc()),
|
start: Timestamp(OffsetDateTime::now_utc()),
|
||||||
};
|
};
|
||||||
|
|
||||||
// Reserve work so other workers don't choose it
|
// Reserve work so other workers don't choose it
|
||||||
|
|
|
||||||
|
|
@ -2,55 +2,14 @@
|
||||||
|
|
||||||
use std::{collections::HashMap, fmt};
|
use std::{collections::HashMap, fmt};
|
||||||
|
|
||||||
use serde::{de, Deserialize, Serialize};
|
use serde::{Deserialize, Serialize};
|
||||||
use serde_repr::{Deserialize_repr, Serialize_repr};
|
|
||||||
use time::{format_description::well_known::Rfc3339, OffsetDateTime};
|
use crate::primitive::{Source, Timestamp};
|
||||||
|
|
||||||
fn is_false(b: &bool) -> bool {
|
fn is_false(b: &bool) -> bool {
|
||||||
!b
|
!b
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Copy)]
|
|
||||||
pub struct Rfc3339Time(pub OffsetDateTime);
|
|
||||||
|
|
||||||
impl serde::Serialize for Rfc3339Time {
|
|
||||||
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
|
|
||||||
where
|
|
||||||
S: serde::Serializer,
|
|
||||||
{
|
|
||||||
self.0.format(&Rfc3339).unwrap().serialize(serializer)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<'de> serde::Deserialize<'de> for Rfc3339Time {
|
|
||||||
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
|
|
||||||
where
|
|
||||||
D: serde::Deserializer<'de>,
|
|
||||||
{
|
|
||||||
let input: &str = serde::Deserialize::deserialize(deserializer)?;
|
|
||||||
OffsetDateTime::parse(input, &Rfc3339)
|
|
||||||
.map_err(de::Error::custom)
|
|
||||||
.map(Self)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Serialize_repr, Deserialize_repr, sqlx::Type)]
|
|
||||||
#[repr(u8)]
|
|
||||||
pub enum Source {
|
|
||||||
// TODO Internal = 0 ?
|
|
||||||
// Stdin would be fd 0
|
|
||||||
Stdout = 1,
|
|
||||||
Stderr = 2,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Serialize_repr, Deserialize_repr, sqlx::Type)]
|
|
||||||
#[repr(i8)]
|
|
||||||
pub enum Direction {
|
|
||||||
LessIsBetter = -1,
|
|
||||||
Neutral = 0,
|
|
||||||
MoreIsBetter = 1,
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(Clone, Serialize, Deserialize)]
|
#[derive(Clone, Serialize, Deserialize)]
|
||||||
pub struct Measurement {
|
pub struct Measurement {
|
||||||
pub value: f64,
|
pub value: f64,
|
||||||
|
|
@ -81,7 +40,7 @@ pub struct Run {
|
||||||
pub id: String,
|
pub id: String,
|
||||||
pub hash: String,
|
pub hash: String,
|
||||||
pub bench_method: BenchMethod,
|
pub bench_method: BenchMethod,
|
||||||
pub start: Rfc3339Time,
|
pub start: Timestamp,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Serialize, Deserialize)]
|
#[derive(Clone, Serialize, Deserialize)]
|
||||||
|
|
@ -89,7 +48,7 @@ pub struct UnfinishedRun {
|
||||||
pub id: String,
|
pub id: String,
|
||||||
pub hash: String,
|
pub hash: String,
|
||||||
pub bench_method: String,
|
pub bench_method: String,
|
||||||
pub start: Rfc3339Time,
|
pub start: Timestamp,
|
||||||
|
|
||||||
#[serde(default)]
|
#[serde(default)]
|
||||||
pub last_output: Vec<(Source, String)>,
|
pub last_output: Vec<(Source, String)>,
|
||||||
|
|
@ -100,13 +59,13 @@ pub struct FinishedRun {
|
||||||
pub id: String,
|
pub id: String,
|
||||||
pub hash: String,
|
pub hash: String,
|
||||||
pub bench_method: String,
|
pub bench_method: String,
|
||||||
pub start: Rfc3339Time,
|
pub start: Timestamp,
|
||||||
|
|
||||||
/// Override the server's end time.
|
/// Override the server's end time.
|
||||||
///
|
///
|
||||||
/// Should not be used in normal operation, but can be used when importing
|
/// Should not be used in normal operation, but can be used when importing
|
||||||
/// completed runs from other sources.
|
/// completed runs from other sources.
|
||||||
pub end: Option<Rfc3339Time>,
|
pub end: Option<Timestamp>,
|
||||||
|
|
||||||
#[serde(default)]
|
#[serde(default)]
|
||||||
pub exit_code: i32,
|
pub exit_code: i32,
|
||||||
|
|
|
||||||
|
|
@ -10,7 +10,8 @@ use tokio::sync::Notify;
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
config::WorkerServerConfig,
|
config::WorkerServerConfig,
|
||||||
shared::{BenchMethod, FinishedRun, Measurement, Run, Source, UnfinishedRun},
|
primitive::Source,
|
||||||
|
shared::{BenchMethod, FinishedRun, Measurement, Run, UnfinishedRun},
|
||||||
};
|
};
|
||||||
|
|
||||||
use super::server::Server;
|
use super::server::Server;
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue