TemplateContext

Struct TemplateContext 

Source
pub struct TemplateContext {
    pub vars: HashMap<String, Value>,
    pub matrix: HashMap<String, Value>,
    pub otel: HashMap<String, Value>,
}
Expand description

Template context with vars, matrix, otel namespaces

Provides structured access to template variables:

  • vars.* - User-defined variables
  • matrix.* - Matrix testing parameters
  • otel.* - OpenTelemetry configuration

Fields§

§vars: HashMap<String, Value>

User-defined variables

§matrix: HashMap<String, Value>

Matrix testing parameters

§otel: HashMap<String, Value>

OpenTelemetry configuration

Implementations§

Source§

impl TemplateContext

Source

pub fn new() -> Self

Create new empty template context

Source

pub fn with_defaults() -> Self

Create context with default PRD v1.0 variables resolved via precedence

Resolves standard variables following precedence:

  • svc: SERVICE_NAME → “clnrm”
  • env: ENV → “ci”
  • endpoint: OTEL_ENDPOINT → “http://localhost:4318”
  • exporter: OTEL_TRACES_EXPORTER → “otlp”
  • image: CLNRM_IMAGE → “registry/clnrm:1.0.0”
  • freeze_clock: FREEZE_CLOCK → “2025-01-01T00:00:00Z”
  • token: OTEL_TOKEN → “”
Source

pub fn add_var_with_precedence( &mut self, key: &str, env_key: &str, default: &str, )

Add variable with precedence resolution

Resolves value with priority: existing var → ENV → default

§Arguments
  • key - Variable name
  • env_key - Environment variable name
  • default - Default value if not found
Source

pub fn with_vars(self, vars: HashMap<String, Value>) -> Self

Set user-defined variables

Source

pub fn with_matrix(self, matrix: HashMap<String, Value>) -> Self

Set matrix testing parameters

Source

pub fn with_otel(self, otel: HashMap<String, Value>) -> Self

Set OpenTelemetry configuration

Source

pub fn to_tera_context(&self) -> Result<Context>

Convert to Tera context for rendering

Injects variables at both top-level (no prefix) and nested [vars] for authoring. This matches PRD v1.0 requirements for no-prefix template variables.

Source

pub fn add_var(&mut self, key: String, value: Value)

Add a variable to the vars namespace

Source

pub fn add_matrix_param(&mut self, key: String, value: Value)

Add a matrix parameter

Source

pub fn add_otel_config(&mut self, key: String, value: Value)

Add an OTEL configuration value

Source

pub fn merge_user_vars(&mut self, user_vars: HashMap<String, Value>)

Merge user-provided variables with defaults

User variables take precedence over defaults (implements precedence chain)

Trait Implementations§

Source§

impl Clone for TemplateContext

Source§

fn clone(&self) -> TemplateContext

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for TemplateContext

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for TemplateContext

Source§

fn default() -> TemplateContext

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Fake for T

Source§

fn fake<U>(&self) -> U
where Self: FakeBase<U>,

Source§

fn fake_with_rng<U, R>(&self, rng: &mut R) -> U
where R: Rng + ?Sized, Self: FakeBase<U>,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V