()
| 151 | } |
| 152 | |
| 153 | func (p *rsyncProvider) Start() error { |
| 154 | p.Lock() |
| 155 | defer p.Unlock() |
| 156 | |
| 157 | if p.IsRunning() { |
| 158 | return errors.New("provider is currently running") |
| 159 | } |
| 160 | |
| 161 | command := []string{p.rsyncCmd} |
| 162 | command = append(command, p.options...) |
| 163 | command = append(command, p.upstreamURL, p.WorkingDir()) |
| 164 | |
| 165 | p.cmd = newCmdJob(p, command, p.WorkingDir(), p.rsyncEnv) |
| 166 | if err := p.prepareLogFile(false); err != nil { |
| 167 | return err |
| 168 | } |
| 169 | |
| 170 | if err := p.cmd.Start(); err != nil { |
| 171 | return err |
| 172 | } |
| 173 | p.isRunning.Store(true) |
| 174 | logger.Debugf("set isRunning to true: %s", p.Name()) |
| 175 | return nil |
| 176 | } |
no test coverage detected