2020-01-30 03:51:06 +03:00
|
|
|
/*
|
|
|
|
DESCRIPTION
|
|
|
|
geovision_test.go tests the geovision AVDevice.
|
|
|
|
|
|
|
|
AUTHORS
|
|
|
|
Scott Barnard <scott@ausocean.org>
|
|
|
|
|
|
|
|
LICENSE
|
|
|
|
Copyright (C) 2020 the Australian Ocean Lab (AusOcean)
|
|
|
|
|
|
|
|
It is free software: you can redistribute it and/or modify them
|
|
|
|
under the terms of the GNU General Public License as published by the
|
|
|
|
Free Software Foundation, either version 3 of the License, or (at your
|
|
|
|
option) any later version.
|
|
|
|
|
|
|
|
It is distributed in the hope that it will be useful, but WITHOUT
|
|
|
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
|
|
for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
in gpl.txt. If not, see http://www.gnu.org/licenses.
|
|
|
|
*/
|
|
|
|
|
2020-03-12 08:26:29 +03:00
|
|
|
// Package geovision provides an implementation of the AVDevice interface
|
|
|
|
// for the GeoVision IP camera.
|
2020-01-30 03:51:06 +03:00
|
|
|
package geovision
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"testing"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"bitbucket.org/ausocean/av/codec/codecutil"
|
|
|
|
"bitbucket.org/ausocean/av/revid/config"
|
|
|
|
"bitbucket.org/ausocean/utils/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestIsRunning(t *testing.T) {
|
2020-01-31 04:52:48 +03:00
|
|
|
const dur = 250 * time.Millisecond
|
|
|
|
const ip = "192.168.4.20"
|
|
|
|
|
2020-01-30 03:51:06 +03:00
|
|
|
l := logger.New(logger.Debug, &bytes.Buffer{}, true) // Discard logs.
|
|
|
|
d := New(l)
|
|
|
|
|
2020-01-31 04:52:48 +03:00
|
|
|
err := d.Set(config.Config{
|
2020-01-30 03:51:06 +03:00
|
|
|
Logger: l,
|
|
|
|
InputCodec: codecutil.H264,
|
2020-01-31 04:52:48 +03:00
|
|
|
CameraIP: ip,
|
2020-01-30 03:51:06 +03:00
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
t.Skipf("could not set device: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
err = d.Start()
|
|
|
|
if err != nil {
|
2020-01-31 06:32:45 +03:00
|
|
|
t.Fatalf("could not start device %w", err)
|
2020-01-30 03:51:06 +03:00
|
|
|
}
|
2020-01-31 04:52:48 +03:00
|
|
|
|
|
|
|
time.Sleep(dur)
|
|
|
|
|
2020-01-30 03:51:06 +03:00
|
|
|
if !d.IsRunning() {
|
|
|
|
t.Error("device isn't running, when it should be")
|
|
|
|
}
|
|
|
|
|
|
|
|
err = d.Stop()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err.Error())
|
|
|
|
}
|
2020-01-31 04:52:48 +03:00
|
|
|
|
|
|
|
time.Sleep(dur)
|
|
|
|
|
2020-01-30 03:51:06 +03:00
|
|
|
if d.IsRunning() {
|
|
|
|
t.Error("device is running, when it should not be")
|
|
|
|
}
|
|
|
|
}
|