mirror of
https://github.com/ultravioletrs/cocos.git
synced 2026-06-23 04:10:25 +00:00
4e8057f481
CI / ci (push) Has been cancelled
* Implement IMAMeasurements method in agentSDK and add corresponding unit tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add unit tests for NewIMAMeasurements command in CLI Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add error assertion for command execution in NewIMAMeasurements test Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Fix nil pointer dereference in Close method and update NewCreateVMCmd logic for manager client initialization Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Refactor file permission settings to use octal notation and improve cleanup handling in NewCreateVMCmd test Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add comprehensive unit tests for state machine functionality Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add mock implementation for Algorithm interface and corresponding test cases Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Refactor file permission settings to use octal notation in TestStopComputationIntegration Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Remove redundant reset test cases from TestStateMachine_Reset Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Fix race condition in action call verification in TestStateMachine_HandleEvent Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Enhance state machine with reset functionality and improve thread safety in event handling Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Improve error handling in state machine start function during tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Remove concurrent reset and send event test from state machine tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Remove error logging for Start function in transition tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add mock implementations for AgentService_IMAMeasurementsClient and Service Shutdown method; enhance progress tests for IMA measurements handling Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add comprehensive tests for FileStorage functionality including loading, saving, and concurrent access Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Enhance tests by adding dataset and algorithm hashes in handleRunReqChunks; improve error handling in TestFileStorage_ErrorHandling cleanup Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Enhance TestManagerClient_Process by adding new test cases for Agent state and Disconnect requests; update setupMocks to include grpcClient Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Fix graceful shutdown in gRPC server by adding nil checks for health and server instances Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Enhance TestAttestation by adding mock expectations for VTpmAttestation and Attestation methods; update service call to include platform parameter Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Enhance gRPC Server by adding synchronization for start/stop methods; prevent multiple starts and ensure graceful shutdown Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add unit tests for gRPC server methods including VM creation, removal, and info retrieval Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add tests for SEVSNP and TDX host capabilities; remove unused vsock code Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add a newline for better readability in vm_test.go Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add integration tests for gRPC client in cvm_test.go Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Remove unused vsock dependencies and add comprehensive unit tests for GCP attestation functions Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Skip GCP tests if credentials are not set Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add tests for error handling in attestation configuration and GCP commands Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Improve error handling in Azure VM test response writing Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Skip tests in GCP functions if credentials are not set Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add comprehensive unit tests for Azure attestation provider and verifier Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add unit tests for TPM functionality and improve error handling Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add comprehensive tests for attestation functionality and improve error handling Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add validation for teeNonce in TeeAttestation and implement comprehensive tests for provider methods Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Refactor error messages in TDX attestation tests for clarity Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Fix error message in TeeAttestation test for valid nonce case Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add MeasurementProvider mock and update mockery configuration Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Add logging for product in parseUints and rename test functions for clarity Signed-off-by: Sammy Oina <sammyoina@gmail.com> * Refactor TestSevsnpverify to reset configuration and improve error logging Signed-off-by: Sammy Oina <sammyoina@gmail.com> --------- Signed-off-by: Sammy Oina <sammyoina@gmail.com>
148 lines
2.8 KiB
Go
148 lines
2.8 KiB
Go
// Copyright (c) Ultraviolet
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
package statemachine
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"sync"
|
|
)
|
|
|
|
type State interface {
|
|
String() string
|
|
}
|
|
|
|
type Event interface {
|
|
String() string
|
|
}
|
|
|
|
type Action func(State)
|
|
|
|
type Transition struct {
|
|
From State
|
|
Event Event
|
|
To State
|
|
}
|
|
|
|
type StateMachine interface {
|
|
AddTransition(t Transition)
|
|
SetAction(state State, action Action)
|
|
GetState() State
|
|
SendEvent(event Event)
|
|
Start(ctx context.Context) error
|
|
Reset(initialState State)
|
|
}
|
|
|
|
type stateMachine struct {
|
|
mu sync.Mutex
|
|
currentState State
|
|
transitions map[State]map[Event]State
|
|
actions map[State]Action
|
|
eventChan chan Event
|
|
resetChan chan struct{}
|
|
}
|
|
|
|
func NewStateMachine(initialState State) StateMachine {
|
|
return &stateMachine{
|
|
currentState: initialState,
|
|
transitions: make(map[State]map[Event]State),
|
|
actions: make(map[State]Action),
|
|
eventChan: make(chan Event),
|
|
resetChan: make(chan struct{}),
|
|
}
|
|
}
|
|
|
|
func (sm *stateMachine) AddTransition(t Transition) {
|
|
sm.mu.Lock()
|
|
defer sm.mu.Unlock()
|
|
|
|
if _, ok := sm.transitions[t.From]; !ok {
|
|
sm.transitions[t.From] = make(map[Event]State)
|
|
}
|
|
sm.transitions[t.From][t.Event] = t.To
|
|
}
|
|
|
|
func (sm *stateMachine) SetAction(state State, action Action) {
|
|
sm.mu.Lock()
|
|
defer sm.mu.Unlock()
|
|
|
|
sm.actions[state] = action
|
|
}
|
|
|
|
func (sm *stateMachine) GetState() State {
|
|
sm.mu.Lock()
|
|
defer sm.mu.Unlock()
|
|
return sm.currentState
|
|
}
|
|
|
|
func (sm *stateMachine) SendEvent(event Event) {
|
|
sm.mu.Lock()
|
|
eventChan := sm.eventChan
|
|
sm.mu.Unlock()
|
|
|
|
select {
|
|
case eventChan <- event:
|
|
default:
|
|
// Channel might be closed or full, ignore the event
|
|
}
|
|
}
|
|
|
|
func (sm *stateMachine) Start(ctx context.Context) error {
|
|
for {
|
|
sm.mu.Lock()
|
|
eventChan := sm.eventChan
|
|
resetChan := sm.resetChan
|
|
sm.mu.Unlock()
|
|
|
|
select {
|
|
case event := <-eventChan:
|
|
if err := sm.handleEvent(event); err != nil {
|
|
return err
|
|
}
|
|
case <-resetChan:
|
|
continue
|
|
case <-ctx.Done():
|
|
return ctx.Err()
|
|
}
|
|
}
|
|
}
|
|
|
|
func (sm *stateMachine) Reset(initialState State) {
|
|
sm.mu.Lock()
|
|
defer sm.mu.Unlock()
|
|
|
|
// Reset current state to initial state
|
|
sm.currentState = initialState
|
|
|
|
// Close the existing event channel to stop processing events
|
|
close(sm.eventChan)
|
|
|
|
// Close the reset channel to signal Start() to restart
|
|
close(sm.resetChan)
|
|
|
|
sm.eventChan = make(chan Event)
|
|
sm.resetChan = make(chan struct{})
|
|
}
|
|
|
|
func (sm *stateMachine) handleEvent(event Event) error {
|
|
sm.mu.Lock()
|
|
currentState := sm.currentState
|
|
nextState, valid := sm.transitions[currentState][event]
|
|
sm.mu.Unlock()
|
|
|
|
if !valid {
|
|
return fmt.Errorf("invalid transition: %v -> %v", currentState, event)
|
|
}
|
|
|
|
sm.mu.Lock()
|
|
sm.currentState = nextState
|
|
action := sm.actions[nextState]
|
|
sm.mu.Unlock()
|
|
|
|
if action != nil {
|
|
go action(nextState)
|
|
}
|
|
|
|
return nil
|
|
}
|