github.com/e154/smart-home@v0.17.2-0.20240311175135-e530a6e5cd45/common/telemetry/telemetry_test.go (about)

     1  // This file is part of the Smart Home
     2  // Program complex distribution https://github.com/e154/smart-home
     3  // Copyright (C) 2023, Filippov Alex
     4  //
     5  // This library is free software: you can redistribute it and/or
     6  // modify it under the terms of the GNU Lesser General Public
     7  // License as published by the Free Software Foundation; either
     8  // version 3 of the License, or (at your option) any later version.
     9  //
    10  // This library is distributed in the hope that it will be useful,
    11  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    12  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    13  // Library General Public License for more details.
    14  //
    15  // You should have received a copy of the GNU Lesser General Public
    16  // License along with this library.  If not, see
    17  // <https://www.gnu.org/licenses/>.
    18  
    19  package telemetry
    20  
    21  import (
    22  	"context"
    23  	"testing"
    24  	"time"
    25  
    26  	"github.com/e154/smart-home/common/debug"
    27  )
    28  
    29  func TestTelemetry(t *testing.T) {
    30  
    31  	ctx := context.Background()
    32  
    33  	triggerCtx, triggerSpan := Start(ctx, "trigger")
    34  	triggerSpan.SetAttributes("trigger.id", 1)
    35  	time.Sleep(time.Millisecond * 500)
    36  	triggerSpan.End()
    37  
    38  	taskCtx, taskSpan := Start(triggerCtx, "task")
    39  	taskSpan.SetAttributes("task.id", 1)
    40  
    41  	conditionsCtx, conditionsSpan := Start(taskCtx, "conditions")
    42  	conditionsSpan.SetAttributes("condition.id", 1)
    43  	time.Sleep(time.Millisecond * 500)
    44  	conditionsSpan.End()
    45  
    46  	actionsCtx, actionsSpan := Start(conditionsCtx, "actions")
    47  	actionsSpan.SetAttributes("action.id", 1)
    48  	time.Sleep(time.Millisecond * 500)
    49  	actionsSpan.End()
    50  
    51  	taskSpan.End()
    52  
    53  	//layers := Unpack(actionsCtx)
    54  	//require.Equal(t, 2, len(layers))
    55  
    56  	debug.Println(Unpack(actionsCtx))
    57  }