You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
6.3 KiB
208 lines
6.3 KiB
/*
|
|
* Minio Cloud Storage, (C) 2014 Minio, Inc.
|
|
*
|
|
* 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
|
|
*
|
|
* http://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 controller
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"net/http"
|
|
"net/http/httptest"
|
|
"os"
|
|
"testing"
|
|
|
|
jsonrpc "github.com/gorilla/rpc/v2/json"
|
|
"github.com/minio/minio/pkg/auth"
|
|
"github.com/minio/minio/pkg/controller/rpc"
|
|
. "gopkg.in/check.v1"
|
|
)
|
|
|
|
// Hook up gocheck into the "go test" runner.
|
|
func Test(t *testing.T) { TestingT(t) }
|
|
|
|
type MySuite struct{}
|
|
|
|
var _ = Suite(&MySuite{})
|
|
|
|
var testRPCServer *httptest.Server
|
|
|
|
func (s *MySuite) SetUpSuite(c *C) {
|
|
root, err := ioutil.TempDir(os.TempDir(), "api-")
|
|
c.Assert(err, IsNil)
|
|
auth.SetAuthConfigPath(root)
|
|
|
|
testRPCServer = httptest.NewServer(getRPCHandler())
|
|
}
|
|
|
|
func (s *MySuite) TearDownSuite(c *C) {
|
|
testRPCServer.Close()
|
|
}
|
|
|
|
func (s *MySuite) TestMemStats(c *C) {
|
|
op := rpc.Operation{
|
|
Method: "Server.MemStats",
|
|
Request: rpc.ServerArgs{},
|
|
}
|
|
req, err := rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err := req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var reply rpc.MemStatsReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &reply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(reply, Not(DeepEquals), rpc.MemStatsReply{})
|
|
}
|
|
|
|
func (s *MySuite) TestSysInfo(c *C) {
|
|
op := rpc.Operation{
|
|
Method: "Server.SysInfo",
|
|
Request: rpc.ServerArgs{},
|
|
}
|
|
req, err := rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err := req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var reply rpc.SysInfoReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &reply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(reply, Not(DeepEquals), rpc.SysInfoReply{})
|
|
}
|
|
|
|
func (s *MySuite) TestServerList(c *C) {
|
|
op := rpc.Operation{
|
|
Method: "Server.List",
|
|
Request: rpc.ServerArgs{},
|
|
}
|
|
req, err := rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err := req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var reply rpc.ServerListReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &reply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(reply, Not(DeepEquals), rpc.ServerListReply{})
|
|
}
|
|
|
|
func (s *MySuite) TestServerAdd(c *C) {
|
|
op := rpc.Operation{
|
|
Method: "Server.Add",
|
|
Request: rpc.ServerArgs{MinioServers: []rpc.MinioServer{}},
|
|
}
|
|
req, err := rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err := req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var reply rpc.ServerAddReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &reply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(reply, Not(DeepEquals), rpc.ServerAddReply{ServersAdded: []rpc.MinioServer{}})
|
|
}
|
|
|
|
func (s *MySuite) TestAuth(c *C) {
|
|
op := rpc.Operation{
|
|
Method: "Auth.Generate",
|
|
Request: rpc.AuthArgs{User: "newuser"},
|
|
}
|
|
req, err := rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err := req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var reply rpc.AuthReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &reply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(reply, Not(DeepEquals), rpc.AuthReply{})
|
|
c.Assert(len(reply.AccessKeyID), Equals, 20)
|
|
c.Assert(len(reply.SecretAccessKey), Equals, 40)
|
|
c.Assert(len(reply.Name), Not(Equals), 0)
|
|
|
|
op = rpc.Operation{
|
|
Method: "Auth.Fetch",
|
|
Request: rpc.AuthArgs{User: "newuser"},
|
|
}
|
|
req, err = rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err = req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var newReply rpc.AuthReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &newReply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(newReply, Not(DeepEquals), rpc.AuthReply{})
|
|
c.Assert(reply.AccessKeyID, Equals, newReply.AccessKeyID)
|
|
c.Assert(reply.SecretAccessKey, Equals, newReply.SecretAccessKey)
|
|
c.Assert(len(reply.Name), Not(Equals), 0)
|
|
|
|
op = rpc.Operation{
|
|
Method: "Auth.Reset",
|
|
Request: rpc.AuthArgs{User: "newuser"},
|
|
}
|
|
req, err = rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err = req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusOK)
|
|
|
|
var resetReply rpc.AuthReply
|
|
c.Assert(jsonrpc.DecodeClientResponse(resp.Body, &resetReply), IsNil)
|
|
resp.Body.Close()
|
|
c.Assert(newReply, Not(DeepEquals), rpc.AuthReply{})
|
|
c.Assert(reply.AccessKeyID, Not(Equals), resetReply.AccessKeyID)
|
|
c.Assert(reply.SecretAccessKey, Not(Equals), resetReply.SecretAccessKey)
|
|
c.Assert(len(reply.Name), Not(Equals), 0)
|
|
|
|
// these operations should fail
|
|
|
|
/// generating access for existing user fails
|
|
op = rpc.Operation{
|
|
Method: "Auth.Generate",
|
|
Request: rpc.AuthArgs{User: "newuser"},
|
|
}
|
|
req, err = rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err = req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusBadRequest)
|
|
|
|
/// null user provided invalid
|
|
op = rpc.Operation{
|
|
Method: "Auth.Generate",
|
|
Request: rpc.AuthArgs{User: ""},
|
|
}
|
|
req, err = rpc.NewRequest(testRPCServer.URL+"/rpc", op, http.DefaultTransport)
|
|
c.Assert(err, IsNil)
|
|
c.Assert(req.Get("Content-Type"), Equals, "application/json")
|
|
resp, err = req.Do()
|
|
c.Assert(err, IsNil)
|
|
c.Assert(resp.StatusCode, Equals, http.StatusBadRequest)
|
|
}
|
|
|