miniflux-v2/integration_test.go

314 lines
8.0 KiB
Go
Raw Normal View History

2017-11-25 19:40:23 +01:00
// Copyright 2017 Frédéric Guillot. All rights reserved.
// Use of this source code is governed by the Apache 2.0
// license that can be found in the LICENSE file.
// +build integration
package main
import (
2017-11-25 21:44:32 +01:00
"math/rand"
"strconv"
"strings"
2017-11-25 19:40:23 +01:00
"testing"
2017-11-25 21:44:32 +01:00
"time"
2017-11-25 19:40:23 +01:00
"github.com/miniflux/miniflux-go"
)
const (
2017-11-25 21:44:32 +01:00
testBaseURL = "http://127.0.0.1:8080"
testAdminUsername = "admin"
testAdminPassword = "test123"
testStandardPassword = "secret"
2017-11-25 19:40:23 +01:00
)
2017-11-25 21:44:32 +01:00
func TestWithBadEndpoint(t *testing.T) {
client := miniflux.NewClient("bad url", testAdminUsername, testAdminPassword)
_, err := client.Users()
if err == nil {
t.Fatal(`Using a bad url should raise an error`)
}
}
func TestWithWrongCredentials(t *testing.T) {
client := miniflux.NewClient(testBaseURL, "invalid", "invalid")
_, err := client.Users()
if err == nil {
t.Fatal(`Using bad credentials should raise an error`)
}
}
2017-11-25 19:40:23 +01:00
func TestGetUsers(t *testing.T) {
2017-11-25 21:44:32 +01:00
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
2017-11-25 19:40:23 +01:00
users, err := client.Users()
if err != nil {
t.Fatal(err)
}
if len(users) == 0 {
t.Fatal("The list of users is empty")
}
if users[0].ID == 0 {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid userID, got "%v"`, users[0].ID)
2017-11-25 19:40:23 +01:00
}
2017-11-25 21:44:32 +01:00
if users[0].Username != testAdminUsername {
t.Fatalf(`Invalid username, got "%v" instead of "%v"`, users[0].Username, testAdminUsername)
2017-11-25 19:40:23 +01:00
}
if users[0].Password != "" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid password, got "%v"`, users[0].Password)
2017-11-25 19:40:23 +01:00
}
if users[0].Language != "en_US" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid language, got "%v"`, users[0].Language)
2017-11-25 19:40:23 +01:00
}
if users[0].Theme != "default" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid theme, got "%v"`, users[0].Theme)
2017-11-25 19:40:23 +01:00
}
if users[0].Timezone != "UTC" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid timezone, got "%v"`, users[0].Timezone)
2017-11-25 19:40:23 +01:00
}
if !users[0].IsAdmin {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid role, got "%v"`, users[0].IsAdmin)
2017-11-25 19:40:23 +01:00
}
}
func TestCreateStandardUser(t *testing.T) {
2017-11-25 21:44:32 +01:00
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
if user.ID == 0 {
t.Fatalf(`Invalid userID, got "%v"`, user.ID)
}
if user.Username != username {
t.Fatalf(`Invalid username, got "%v" instead of "%v"`, user.Username, username)
}
if user.Password != "" {
t.Fatalf(`Invalid password, got "%v"`, user.Password)
}
if user.Language != "en_US" {
t.Fatalf(`Invalid language, got "%v"`, user.Language)
}
if user.Theme != "default" {
t.Fatalf(`Invalid theme, got "%v"`, user.Theme)
}
if user.Timezone != "UTC" {
t.Fatalf(`Invalid timezone, got "%v"`, user.Timezone)
}
if user.IsAdmin {
t.Fatalf(`Invalid role, got "%v"`, user.IsAdmin)
}
if user.LastLoginAt != nil {
t.Fatalf(`Invalid last login date, got "%v"`, user.LastLoginAt)
}
}
func TestRemoveUser(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
if err := client.DeleteUser(user.ID); err != nil {
t.Fatalf(`Unable to remove user: "%v"`, err)
}
}
func TestGetUser(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
user, err = client.User(user.ID)
2017-11-25 19:40:23 +01:00
if err != nil {
t.Fatal(err)
}
if user.ID == 0 {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid userID, got "%v"`, user.ID)
2017-11-25 19:40:23 +01:00
}
2017-11-25 21:44:32 +01:00
if user.Username != username {
t.Fatalf(`Invalid username, got "%v" instead of "%v"`, user.Username, username)
2017-11-25 19:40:23 +01:00
}
if user.Password != "" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid password, got "%v"`, user.Password)
2017-11-25 19:40:23 +01:00
}
if user.Language != "en_US" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid language, got "%v"`, user.Language)
2017-11-25 19:40:23 +01:00
}
if user.Theme != "default" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid theme, got "%v"`, user.Theme)
2017-11-25 19:40:23 +01:00
}
if user.Timezone != "UTC" {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid timezone, got "%v"`, user.Timezone)
2017-11-25 19:40:23 +01:00
}
if user.IsAdmin {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid role, got "%v"`, user.IsAdmin)
2017-11-25 19:40:23 +01:00
}
if user.LastLoginAt != nil {
2017-11-25 21:44:32 +01:00
t.Fatalf(`Invalid last login date, got "%v"`, user.LastLoginAt)
}
}
func TestUpdateUser(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
theme := "black"
user.Theme = theme
user, err = client.UpdateUser(user)
if err != nil {
t.Fatal(err)
}
if user.Theme != theme {
t.Fatalf(`Unable to update user: got "%v" instead of "%v"`, user.Theme, theme)
}
}
func TestUpdateUserWithInvalidValue(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
theme := "something that doesn't exists"
user.Theme = theme
_, err = client.UpdateUser(user)
if err == nil {
t.Fatal(`Updating a user with an invalid value should raise an error`)
}
}
func TestCannotCreateDuplicateUser(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
_, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
_, err = client.CreateUser(username, testStandardPassword, false)
if err == nil {
t.Fatal(`Duplicate users should not be allowed`)
}
}
func TestCannotListUsersAsNonAdmin(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
_, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
client = miniflux.NewClient(testBaseURL, username, testStandardPassword)
_, err = client.Users()
if err == nil {
t.Fatal(`Standard users should not be able to list any users`)
}
}
func TestCannotGetUserAsNonAdmin(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
client = miniflux.NewClient(testBaseURL, username, testStandardPassword)
_, err = client.User(user.ID)
if err == nil {
t.Fatal(`Standard users should not be able to get any users`)
}
}
func TestCannotUpdateUserAsNonAdmin(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
client = miniflux.NewClient(testBaseURL, username, testStandardPassword)
_, err = client.UpdateUser(user)
if err == nil {
t.Fatal(`Standard users should not be able to update any users`)
}
}
func TestCannotCreateUserAsNonAdmin(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
_, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
client = miniflux.NewClient(testBaseURL, username, testStandardPassword)
_, err = client.CreateUser(username, testStandardPassword, false)
if err == nil {
t.Fatal(`Standard users should not be able to create users`)
}
}
func TestCannotDeleteUserAsNonAdmin(t *testing.T) {
username := getRandomUsername()
client := miniflux.NewClient(testBaseURL, testAdminUsername, testAdminPassword)
user, err := client.CreateUser(username, testStandardPassword, false)
if err != nil {
t.Fatal(err)
}
client = miniflux.NewClient(testBaseURL, username, testStandardPassword)
if err := client.DeleteUser(user.ID); err == nil {
t.Fatal(`Standard users should not be able to remove any users`)
}
}
func getRandomUsername() string {
rand.Seed(time.Now().UnixNano())
var suffix []string
for i := 0; i < 10; i++ {
suffix = append(suffix, strconv.Itoa(rand.Intn(1000)))
2017-11-25 19:40:23 +01:00
}
2017-11-25 21:44:32 +01:00
return "user" + strings.Join(suffix, "")
2017-11-25 19:40:23 +01:00
}