()
| 153 | } |
| 154 | |
| 155 | func (e *engineImpl) reporting() error { |
| 156 | e.log.Info("engine starts to report") |
| 157 | defer e.log.Info("engine has stopped reporting") |
| 158 | |
| 159 | t := time.NewTicker(e.cfg.Engine.Report.Interval) |
| 160 | defer t.Stop() |
| 161 | for { |
| 162 | select { |
| 163 | case <-t.C: |
| 164 | err := e.reportAndDesireAsync(true) |
| 165 | if err != nil { |
| 166 | e.log.Error("failed to report local shadow", log.Error(err)) |
| 167 | } else { |
| 168 | e.log.Debug("engine reports local shadow") |
| 169 | } |
| 170 | case <-e.tomb.Dying(): |
| 171 | return nil |
| 172 | } |
| 173 | } |
| 174 | } |
| 175 | |
| 176 | func (e *engineImpl) reportAndDesireAsync(delete bool) error { |
| 177 | node, err := e.nod.Get() |
nothing calls this directly
no test coverage detected