Skip to content

Commit

Permalink
[add] add uid in events and archive_experiments (chaos-mesh#623)
Browse files Browse the repository at this point in the history
* add uid

* address comment
  • Loading branch information
fewdan authored Jun 15, 2020
1 parent ea2582d commit 5419872
Show file tree
Hide file tree
Showing 3 changed files with 46 additions and 28 deletions.
58 changes: 37 additions & 21 deletions pkg/collector/collector.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,25 +82,36 @@ func (r *ChaosCollector) Setup(mgr ctrl.Manager, apiType runtime.Object) error {
}

func (r *ChaosCollector) recordEvent(req ctrl.Request, obj v1alpha1.InnerObject) error {
var (
chaosMeta metav1.Object
ok bool
)

if chaosMeta, ok = obj.(metav1.Object); !ok {
return errors.New("failed to get chaos meta information")
}

UID := chaosMeta.GetUID()
status := obj.GetStatus()
kind := obj.GetObjectKind().GroupVersionKind().Kind

switch status.Experiment.Phase {
case v1alpha1.ExperimentPhaseRunning:
return r.createEvent(req, kind, status)
return r.createEvent(req, kind, status, string(UID))
case v1alpha1.ExperimentPhaseFinished, v1alpha1.ExperimentPhasePaused:
return r.updateOrCreateEvent(req, kind, status)
return r.updateOrCreateEvent(req, kind, status, string(UID))
}

return nil
}

func (r *ChaosCollector) createEvent(req ctrl.Request, kind string, status *v1alpha1.ChaosStatus) error {
func (r *ChaosCollector) createEvent(req ctrl.Request, kind string, status *v1alpha1.ChaosStatus, UID string) error {
event := &core.Event{
Experiment: req.Name,
Namespace: req.Namespace,
Kind: kind,
StartTime: &status.Experiment.StartTime.Time,
Experiment: req.Name,
Namespace: req.Namespace,
Kind: kind,
StartTime: &status.Experiment.StartTime.Time,
ExperimentID: UID,
}

for _, pod := range status.Experiment.PodRecords {
Expand All @@ -122,18 +133,19 @@ func (r *ChaosCollector) createEvent(req ctrl.Request, kind string, status *v1al
return nil
}

func (r *ChaosCollector) updateOrCreateEvent(req ctrl.Request, kind string, status *v1alpha1.ChaosStatus) error {
func (r *ChaosCollector) updateOrCreateEvent(req ctrl.Request, kind string, status *v1alpha1.ChaosStatus, UID string) error {
event := &core.Event{
Experiment: req.Name,
Namespace: req.Namespace,
Kind: kind,
StartTime: &status.Experiment.StartTime.Time,
FinishTime: &status.Experiment.EndTime.Time,
Experiment: req.Name,
Namespace: req.Namespace,
Kind: kind,
StartTime: &status.Experiment.StartTime.Time,
FinishTime: &status.Experiment.EndTime.Time,
ExperimentID: UID,
}

if _, err := r.event.FindByExperimentAndStartTime(
context.Background(), event.Experiment, event.Namespace, event.StartTime); err != nil && gorm.IsRecordNotFoundError(err) {
if err := r.createEvent(req, kind, status); err != nil {
if err := r.createEvent(req, kind, status, UID); err != nil {
return err
}
}
Expand All @@ -147,11 +159,22 @@ func (r *ChaosCollector) updateOrCreateEvent(req ctrl.Request, kind string, stat
}

func (r *ChaosCollector) archiveExperiment(req ctrl.Request, obj v1alpha1.InnerObject) error {
var (
chaosMeta metav1.Object
ok bool
)

if chaosMeta, ok = obj.(metav1.Object); !ok {
r.Log.Error(nil, "failed to get chaos meta information")
}
UID := chaosMeta.GetUID()

archive := &core.ArchiveExperiment{
ArchiveExperimentMeta: core.ArchiveExperimentMeta{
Namespace: req.Namespace,
Name: req.Name,
Kind: obj.GetObjectKind().GroupVersionKind().Kind,
UID: string(UID),
},
}

Expand All @@ -168,13 +191,6 @@ func (r *ChaosCollector) archiveExperiment(req ctrl.Request, obj v1alpha1.InnerO
return errors.New("unsupported chaos type " + archive.Kind)
}

var (
chaosMeta metav1.Object
ok bool
)
if chaosMeta, ok = obj.(metav1.Object); !ok {
return errors.New("failed to case type to " + archive.Kind)
}
archive.StartTime = chaosMeta.GetCreationTimestamp().Time
archive.FinishTime = chaosMeta.GetDeletionTimestamp().Time

Expand Down
1 change: 1 addition & 0 deletions pkg/core/archive_experiment.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ type ArchiveExperimentMeta struct {
Namespace string
Kind string
Action string
UID string
StartTime time.Time
FinishTime time.Time
}
Expand Down
15 changes: 8 additions & 7 deletions pkg/core/event.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,13 +62,14 @@ type EventStore interface {
// Event represents an event instance.
type Event struct {
gorm.Model
Experiment string `gorm:"index:experiment"`
Namespace string
Kind string
Message string
StartTime *time.Time `gorm:"index:start_time"`
FinishTime *time.Time
Pods []*PodRecord `gorm:"-"`
Experiment string `gorm:"index:experiment"`
Namespace string
Kind string
Message string
ExperimentID string `gorm:"index:experiment_id"`
StartTime *time.Time `gorm:"index:start_time"`
FinishTime *time.Time
Pods []*PodRecord `gorm:"-"`
}

// PodRecord represents a pod record with event ID.
Expand Down

0 comments on commit 5419872

Please sign in to comment.