
This allows for a more class based approach to the types of things that the webservice will be doing going forward. It shunts common tasks to their respective classes to help make it clearer who's doing what where Also removes electron as a type from the ws messages and replaces it with the airshipui type Change-Id: I72786821385244a4c0d93c2cfad73c0d740ef942
243 lines
6.4 KiB
Go
Executable File
243 lines
6.4 KiB
Go
Executable File
/*
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
https://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
package webservice
|
|
|
|
import (
|
|
"encoding/json"
|
|
"testing"
|
|
|
|
"github.com/gorilla/websocket"
|
|
"github.com/stretchr/testify/assert"
|
|
"github.com/stretchr/testify/require"
|
|
"opendev.org/airship/airshipui/internal/configs"
|
|
"opendev.org/airship/airshipui/internal/integrations/ctl"
|
|
"opendev.org/airship/airshipui/testutil"
|
|
)
|
|
|
|
func TestClientInit(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
// simulate config provided by airshipui.json
|
|
configs.UIConfig = testutil.DummyCompleteConfig()
|
|
|
|
// get server response to "initialize" message from client
|
|
response, err := getResponse(client, initialize)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipUI,
|
|
Component: configs.Initialize,
|
|
IsAuthenticated: true,
|
|
Dashboards: []configs.Cluster{
|
|
testutil.DummyClusterConfig(),
|
|
},
|
|
Plugins: []configs.Plugin{
|
|
testutil.DummyPluginWithDashboardConfig(),
|
|
testutil.DummyPluginNoDashboard(),
|
|
},
|
|
Authentication: testutil.DummyAuthMethodConfig(),
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestClientInitNoAuth(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
// simulate config provided by airshipui.json
|
|
configs.UIConfig = testutil.DummyConfigNoAuth()
|
|
|
|
isAuthenticated = false
|
|
|
|
response, err := getResponse(client, initialize)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipUI,
|
|
Component: configs.Initialize,
|
|
// isAuthenticated should now be true in response
|
|
IsAuthenticated: true,
|
|
Dashboards: []configs.Cluster{
|
|
testutil.DummyClusterConfig(),
|
|
},
|
|
Plugins: []configs.Plugin{
|
|
testutil.DummyPluginWithDashboardConfig(),
|
|
testutil.DummyPluginNoDashboard(),
|
|
},
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestKeepalive(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
// get server response to "keepalive" message from client
|
|
response, err := getResponse(client, keepalive)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipUI,
|
|
Component: configs.Keepalive,
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestUnknownType(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
response, err := getResponse(client, unknownType)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: "fake_type",
|
|
Component: configs.Initialize,
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
Error: "Requested type: fake_type, not found",
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestUnknownComponent(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
response, err := getResponse(client, unknownComponent)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipUI,
|
|
Component: "fake_component",
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
Error: "Requested component: fake_component, not found",
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestHandleDocumentRequest(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
expectedHTML, err := ctl.GetDocumentHTML()
|
|
require.NoError(t, err)
|
|
|
|
response, err := getResponse(client, document)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipCTL,
|
|
Component: configs.Document,
|
|
SubComponent: configs.GetDefaults,
|
|
HTML: expectedHTML,
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
}
|
|
|
|
// the non typed interface requires us to break up the checking otherwise the 2 will never be equal
|
|
assert.Equal(t, expected.Type, response.Type)
|
|
assert.Equal(t, expected.Component, response.Component)
|
|
assert.Equal(t, expected.SubComponent, response.SubComponent)
|
|
assert.Equal(t, expected.HTML, response.HTML)
|
|
}
|
|
|
|
func TestHandleBaremetalRequest(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
expectedHTML, err := ctl.GetBaremetalHTML()
|
|
require.NoError(t, err)
|
|
|
|
response, err := getResponse(client, baremetal)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipCTL,
|
|
Component: configs.Baremetal,
|
|
SubComponent: configs.GetDefaults,
|
|
HTML: expectedHTML,
|
|
// don't fail on timestamp diff
|
|
Timestamp: response.Timestamp,
|
|
}
|
|
|
|
assert.Equal(t, expected, response)
|
|
}
|
|
|
|
func TestHandleConfigRequest(t *testing.T) {
|
|
client, err := NewTestClient()
|
|
require.NoError(t, err)
|
|
defer client.Close()
|
|
|
|
response, err := getResponse(client, config)
|
|
require.NoError(t, err)
|
|
|
|
expected := configs.WsMessage{
|
|
Type: configs.AirshipCTL,
|
|
Component: configs.CTLConfig,
|
|
SubComponent: configs.GetDefaults,
|
|
}
|
|
|
|
assert.Equal(t, expected.Type, response.Type)
|
|
assert.Equal(t, expected.Component, response.Component)
|
|
assert.Equal(t, expected.SubComponent, response.SubComponent)
|
|
|
|
// NOTE(mfuller): integrations/ctl 'client' gets initialized
|
|
// *before* any env vars can be set here in tests, so client
|
|
// will always be initialized with default config file locations.
|
|
// Client is not exported, so we can't set it directly here. We'll
|
|
// simply make sure there's no Error value and that HTML has
|
|
// len > 0. Full testing of this response is covered in the
|
|
// integrations/ctl tests.
|
|
|
|
assert.Len(t, response.Error, 0)
|
|
assert.Greater(t, len(response.HTML), 0)
|
|
}
|
|
|
|
func getResponse(client *websocket.Conn, message string) (configs.WsMessage, error) {
|
|
err := client.WriteJSON(json.RawMessage(message))
|
|
if err != nil {
|
|
return configs.WsMessage{}, err
|
|
}
|
|
|
|
var response configs.WsMessage
|
|
err = client.ReadJSON(&response)
|
|
if err != nil {
|
|
return configs.WsMessage{}, err
|
|
}
|
|
|
|
return response, nil
|
|
}
|