2015-02-26 23:03:36 +01:00
/*
Unix SMB / CIFS implementation .
test suite for clusapi rpc operations
Copyright ( C ) Günther Deschner 2015
This program is free software ; you can redistribute it and / or modify
it 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 .
This program 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
along with this program . If not , see < http : //www.gnu.org/licenses/>.
*/
# include "includes.h"
# include "librpc/gen_ndr/ndr_clusapi_c.h"
# include "torture/rpc/torture_rpc.h"
# include "param/param.h"
static bool test_OpenCluster_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * Cluster )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OpenCluster r ;
2015-03-02 20:52:59 +01:00
WERROR Status ;
2015-02-26 23:03:36 +01:00
r . out . Status = & Status ;
r . out . Cluster = Cluster ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OpenCluster_r ( b , tctx , & r ) ,
" OpenCluster failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
* r . out . Status ,
2015-02-26 23:03:36 +01:00
" OpenCluster failed " ) ;
return true ;
}
static bool test_CloseCluster_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * Cluster )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CloseCluster r ;
r . in . Cluster = Cluster ;
r . out . Cluster = Cluster ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CloseCluster_r ( b , tctx , & r ) ,
" CloseCluster failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-02-26 23:03:36 +01:00
" CloseCluster failed " ) ;
torture_assert ( tctx ,
ndr_policy_handle_empty ( Cluster ) ,
" policy_handle non empty after CloseCluster " ) ;
return true ;
}
static bool test_OpenCluster ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle Cluster ;
if ( ! test_OpenCluster_int ( tctx , p , & Cluster ) ) {
return false ;
}
test_CloseCluster_int ( tctx , p , & Cluster ) ;
return true ;
}
static bool test_CloseCluster ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle Cluster ;
if ( ! test_OpenCluster_int ( tctx , p , & Cluster ) ) {
return false ;
}
return test_CloseCluster_int ( tctx , p , & Cluster ) ;
}
2015-02-27 17:45:02 +01:00
static bool test_SetClusterName ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_SetClusterName r ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-02-27 17:45:02 +01:00
r . in . NewClusterName = " wurst " ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_SetClusterName_r ( b , tctx , & r ) ,
" SetClusterName failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-02-27 17:45:02 +01:00
" SetClusterName failed " ) ;
return true ;
}
static bool test_GetClusterName ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetClusterName r ;
const char * ClusterName ;
const char * NodeName ;
r . out . ClusterName = & ClusterName ;
r . out . NodeName = & NodeName ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetClusterName_r ( b , tctx , & r ) ,
" GetClusterName failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-02-27 17:45:02 +01:00
" GetClusterName failed " ) ;
return true ;
}
static bool test_GetClusterVersion ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetClusterVersion r ;
uint16_t lpwMajorVersion ;
uint16_t lpwMinorVersion ;
uint16_t lpwBuildNumber ;
const char * lpszVendorId ;
const char * lpszCSDVersion ;
r . out . lpwMajorVersion = & lpwMajorVersion ;
r . out . lpwMinorVersion = & lpwMinorVersion ;
r . out . lpwBuildNumber = & lpwBuildNumber ;
r . out . lpszVendorId = & lpszVendorId ;
r . out . lpszCSDVersion = & lpszCSDVersion ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetClusterVersion_r ( b , tctx , & r ) ,
" GetClusterVersion failed " ) ;
torture_assert_werr_equal ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-02-27 17:45:02 +01:00
WERR_CALL_NOT_IMPLEMENTED ,
" GetClusterVersion failed " ) ;
return true ;
}
2015-03-03 18:00:55 +01:00
static bool test_GetClusterVersion2 ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetClusterVersion2 r ;
uint16_t lpwMajorVersion ;
uint16_t lpwMinorVersion ;
uint16_t lpwBuildNumber ;
const char * lpszVendorId ;
const char * lpszCSDVersion ;
struct CLUSTER_OPERATIONAL_VERSION_INFO * ppClusterOpVerInfo ;
WERROR rpc_status ;
r . out . lpwMajorVersion = & lpwMajorVersion ;
r . out . lpwMinorVersion = & lpwMinorVersion ;
r . out . lpwBuildNumber = & lpwBuildNumber ;
r . out . lpszVendorId = & lpszVendorId ;
r . out . lpszCSDVersion = & lpszCSDVersion ;
r . out . ppClusterOpVerInfo = & ppClusterOpVerInfo ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetClusterVersion2_r ( b , tctx , & r ) ,
" GetClusterVersion2 failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" GetClusterVersion2 failed " ) ;
return true ;
}
2015-03-06 13:25:24 +01:00
static bool test_CreateEnum ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CreateEnum r ;
uint32_t dwType = CLUSTER_ENUM_RESOURCE ;
struct ENUM_LIST * ReturnEnum ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:25:24 +01:00
r . in . dwType = dwType ;
r . out . ReturnEnum = & ReturnEnum ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CreateEnum_r ( b , tctx , & r ) ,
" CreateEnum failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:25:24 +01:00
" CreateEnum failed " ) ;
return true ;
}
2015-03-06 13:34:44 +01:00
static bool test_GetQuorumResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetQuorumResource r ;
const char * lpszResourceName ;
const char * lpszDeviceName ;
uint32_t pdwMaxQuorumLogSize ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . out . lpszResourceName = & lpszResourceName ;
r . out . lpszDeviceName = & lpszDeviceName ;
r . out . pdwMaxQuorumLogSize = & pdwMaxQuorumLogSize ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetQuorumResource_r ( b , tctx , & r ) ,
" GetQuorumResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" GetQuorumResource failed " ) ;
return true ;
}
static bool test_SetQuorumResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_SetQuorumResource r ;
const char * lpszDeviceName = " " ;
uint32_t dwMaxQuorumLogSize = 0 ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
struct policy_handle hResource ;
/* we need to figure out how this call works and what we provide as
devicename and resource handle - gd
*/
torture_skip ( tctx , " skipping SetQuorumResource test " ) ;
ZERO_STRUCT ( hResource ) ;
r . in . hResource = hResource ;
r . in . lpszDeviceName = lpszDeviceName ;
r . in . dwMaxQuorumLogSize = dwMaxQuorumLogSize ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_SetQuorumResource_r ( b , tctx , & r ) ,
" SetQuorumResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" SetQuorumResource failed " ) ;
return true ;
}
static bool test_OpenResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OpenResource r ;
const char * lpszResourceName = " Cluster Name " ;
2015-03-02 20:52:59 +01:00
WERROR Status ;
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . lpszResourceName = lpszResourceName ;
r . out . rpc_status = & rpc_status ;
r . out . Status = & Status ;
r . out . hResource = hResource ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OpenResource_r ( b , tctx , & r ) ,
" OpenResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
* r . out . Status ,
2015-03-06 13:34:44 +01:00
" OpenResource failed " ) ;
return true ;
}
static bool test_CloseResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CloseResource r ;
r . in . Resource = hResource ;
r . out . Resource = hResource ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CloseResource_r ( b , tctx , & r ) ,
" CloseResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" CloseResource failed " ) ;
torture_assert ( tctx ,
ndr_policy_handle_empty ( hResource ) ,
" policy_handle non empty after CloseResource " ) ;
return true ;
}
static bool test_OpenResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
test_CloseResource_int ( tctx , p , & hResource ) ;
return true ;
}
static bool test_CloseResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
return test_CloseResource_int ( tctx , p , & hResource ) ;
}
2015-03-06 13:51:34 +01:00
static bool test_OpenGroup_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hGroup ) ;
static bool test_CloseGroup_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * Group ) ;
2015-03-06 13:34:44 +01:00
static bool test_CreateResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CreateResource r ;
2015-03-06 13:51:34 +01:00
const char * lpszResourceName = " wurst " ;
const char * lpszResourceType = " Generic Service " ;
2015-03-02 20:52:59 +01:00
WERROR Status ;
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
struct policy_handle hGroup ;
2015-03-06 13:51:34 +01:00
torture_assert ( tctx ,
test_OpenGroup_int ( tctx , p , & hGroup ) ,
" failed to open group " ) ;
2015-03-06 13:34:44 +01:00
r . in . hGroup = hGroup ;
r . in . lpszResourceName = lpszResourceName ;
r . in . lpszResourceType = lpszResourceType ;
r . in . dwFlags = 0 ; /* FIXME */
r . out . rpc_status = & rpc_status ;
r . out . Status = & Status ;
r . out . hResource = hResource ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CreateResource_r ( b , tctx , & r ) ,
" CreateResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
* r . out . Status ,
2015-03-06 13:34:44 +01:00
" CreateResource failed " ) ;
2015-03-06 13:51:34 +01:00
test_CloseGroup_int ( tctx , p , & hGroup ) ;
2015-03-06 13:34:44 +01:00
return true ;
}
static bool test_DeleteResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_DeleteResource r ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_DeleteResource_r ( b , tctx , & r ) ,
" DeleteResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" DeleteResource failed " ) ;
return true ;
}
static bool test_CreateResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
if ( ! test_CreateResource_int ( tctx , p , & hResource ) ) {
return false ;
}
test_DeleteResource_int ( tctx , p , & hResource ) ;
return true ;
}
static bool test_DeleteResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
if ( ! test_CreateResource_int ( tctx , p , & hResource ) ) {
return false ;
}
return test_DeleteResource_int ( tctx , p , & hResource ) ;
}
static bool test_GetResourceState_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetResourceState r ;
uint32_t State ;
const char * NodeName ;
const char * GroupName ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . State = & State ;
r . out . NodeName = & NodeName ;
r . out . GroupName = & GroupName ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetResourceState_r ( b , tctx , & r ) ,
" GetResourceState failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" GetResourceState failed " ) ;
return true ;
}
static bool test_GetResourceState ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_GetResourceState_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
static bool test_GetResourceId_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetResourceId r ;
const char * pGuid ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . pGuid = & pGuid ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetResourceId_r ( b , tctx , & r ) ,
" GetResourceId failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" GetResourceId failed " ) ;
return true ;
}
static bool test_GetResourceId ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_GetResourceId_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
static bool test_GetResourceType_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetResourceType r ;
const char * lpszResourceType ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . lpszResourceType = & lpszResourceType ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetResourceType_r ( b , tctx , & r ) ,
" GetResourceType failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" GetResourceType failed " ) ;
return true ;
}
static bool test_GetResourceType ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_GetResourceType_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
static bool test_FailResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_FailResource r ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_FailResource_r ( b , tctx , & r ) ,
" FailResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" FailResource failed " ) ;
return true ;
}
static bool test_FailResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_FailResource_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
static bool test_OnlineResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OnlineResource r ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OnlineResource_r ( b , tctx , & r ) ,
" OnlineResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" OnlineResource failed " ) ;
return true ;
}
static bool test_OnlineResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_OnlineResource_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
static bool test_OfflineResource_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hResource )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OfflineResource r ;
2015-03-02 20:52:59 +01:00
WERROR rpc_status ;
2015-03-06 13:34:44 +01:00
r . in . hResource = * hResource ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OfflineResource_r ( b , tctx , & r ) ,
" OfflineResource failed " ) ;
torture_assert_werr_ok ( tctx ,
2015-03-02 20:52:59 +01:00
r . out . result ,
2015-03-06 13:34:44 +01:00
" OfflineResource failed " ) ;
return true ;
}
static bool test_OfflineResource ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hResource ;
bool ret = true ;
if ( ! test_OpenResource_int ( tctx , p , & hResource ) ) {
return false ;
}
ret = test_OfflineResource_int ( tctx , p , & hResource ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return ret ;
}
2015-03-04 09:45:56 +01:00
static bool test_CreateResEnum ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CreateResEnum r ;
struct policy_handle hResource ;
uint32_t dwType = CLUSTER_ENUM_RESOURCE ;
struct ENUM_LIST * ReturnEnum ;
WERROR rpc_status ;
torture_assert ( tctx ,
test_OpenResource_int ( tctx , p , & hResource ) ,
" OpenResource failed " ) ;
r . in . hResource = hResource ;
r . in . dwType = dwType ;
r . out . ReturnEnum = & ReturnEnum ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CreateResEnum_r ( b , tctx , & r ) ,
" CreateResEnum failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" CreateResEnum failed " ) ;
test_CloseResource_int ( tctx , p , & hResource ) ;
return true ;
}
2015-03-06 13:34:44 +01:00
2015-03-06 13:49:13 +01:00
static bool test_OpenNode_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OpenNode r ;
const char * lpszNodeName = " NODE1 " ;
WERROR Status ;
WERROR rpc_status ;
r . in . lpszNodeName = lpszNodeName ;
r . out . rpc_status = & rpc_status ;
r . out . Status = & Status ;
r . out . hNode = hNode ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OpenNode_r ( b , tctx , & r ) ,
" OpenNode failed " ) ;
torture_assert_werr_ok ( tctx ,
* r . out . Status ,
" OpenNode failed " ) ;
return true ;
}
static bool test_CloseNode_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * Node )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CloseNode r ;
r . in . Node = Node ;
r . out . Node = Node ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CloseNode_r ( b , tctx , & r ) ,
" CloseNode failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" CloseNode failed " ) ;
torture_assert ( tctx ,
ndr_policy_handle_empty ( Node ) ,
" policy_handle non empty after CloseNode " ) ;
return true ;
}
static bool test_OpenNode ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
test_CloseNode_int ( tctx , p , & hNode ) ;
return true ;
}
static bool test_CloseNode ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
return test_CloseNode_int ( tctx , p , & hNode ) ;
}
static bool test_GetNodeState_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetNodeState r ;
uint32_t State ;
WERROR rpc_status ;
r . in . hNode = * hNode ;
r . out . State = & State ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetNodeState_r ( b , tctx , & r ) ,
" GetNodeState failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" GetNodeState failed " ) ;
return true ;
}
static bool test_GetNodeState ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
bool ret = true ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
ret = test_GetNodeState_int ( tctx , p , & hNode ) ;
test_CloseNode_int ( tctx , p , & hNode ) ;
return ret ;
}
static bool test_GetNodeId_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_GetNodeId r ;
const char * pGuid ;
WERROR rpc_status ;
r . in . hNode = * hNode ;
r . out . pGuid = & pGuid ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_GetNodeId_r ( b , tctx , & r ) ,
" GetNodeId failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" GetNodeId failed " ) ;
return true ;
}
static bool test_GetNodeId ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
bool ret = true ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
ret = test_GetNodeId_int ( tctx , p , & hNode ) ;
test_CloseNode_int ( tctx , p , & hNode ) ;
return ret ;
}
static bool test_PauseNode_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_PauseNode r ;
WERROR rpc_status ;
r . in . hNode = * hNode ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_PauseNode_r ( b , tctx , & r ) ,
" PauseNode failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" PauseNode failed " ) ;
return true ;
}
static bool test_PauseNode ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
bool ret = true ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
ret = test_PauseNode_int ( tctx , p , & hNode ) ;
test_CloseNode_int ( tctx , p , & hNode ) ;
return ret ;
}
static bool test_ResumeNode_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_ResumeNode r ;
WERROR rpc_status ;
r . in . hNode = * hNode ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_ResumeNode_r ( b , tctx , & r ) ,
" ResumeNode failed " ) ;
torture_assert_werr_equal ( tctx ,
r . out . result ,
WERR_CLUSTER_NODE_NOT_PAUSED ,
" ResumeNode gave unexpected result " ) ;
return true ;
}
static bool test_ResumeNode ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
bool ret = true ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
ret = test_ResumeNode_int ( tctx , p , & hNode ) ;
test_CloseNode_int ( tctx , p , & hNode ) ;
return ret ;
}
static bool test_EvictNode_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hNode )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_EvictNode r ;
WERROR rpc_status ;
r . in . hNode = * hNode ;
r . out . rpc_status = & rpc_status ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_EvictNode_r ( b , tctx , & r ) ,
" EvictNode failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" EvictNode failed " ) ;
return true ;
}
static bool test_EvictNode ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hNode ;
bool ret = true ;
if ( ! test_OpenNode_int ( tctx , p , & hNode ) ) {
return false ;
}
ret = test_EvictNode_int ( tctx , p , & hNode ) ;
test_CloseNode_int ( tctx , p , & hNode ) ;
return ret ;
}
2015-03-06 13:50:45 +01:00
static bool test_OpenGroup_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * hGroup )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_OpenGroup r ;
const char * lpszGroupName = " Cluster Group " ;
WERROR Status ;
WERROR rpc_status ;
r . in . lpszGroupName = lpszGroupName ;
r . out . rpc_status = & rpc_status ;
r . out . Status = & Status ;
r . out . hGroup = hGroup ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_OpenGroup_r ( b , tctx , & r ) ,
" OpenGroup failed " ) ;
torture_assert_werr_ok ( tctx ,
* r . out . Status ,
" OpenGroup failed " ) ;
return true ;
}
static bool test_CloseGroup_int ( struct torture_context * tctx ,
struct dcerpc_pipe * p ,
struct policy_handle * Group )
{
struct dcerpc_binding_handle * b = p - > binding_handle ;
struct clusapi_CloseGroup r ;
r . in . Group = Group ;
r . out . Group = Group ;
torture_assert_ntstatus_ok ( tctx ,
dcerpc_clusapi_CloseGroup_r ( b , tctx , & r ) ,
" CloseGroup failed " ) ;
torture_assert_werr_ok ( tctx ,
r . out . result ,
" CloseGroup failed " ) ;
torture_assert ( tctx ,
ndr_policy_handle_empty ( Group ) ,
" policy_handle non empty after CloseGroup " ) ;
return true ;
}
static bool test_OpenGroup ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hGroup ;
if ( ! test_OpenGroup_int ( tctx , p , & hGroup ) ) {
return false ;
}
test_CloseGroup_int ( tctx , p , & hGroup ) ;
return true ;
}
static bool test_CloseGroup ( struct torture_context * tctx ,
struct dcerpc_pipe * p )
{
struct policy_handle hGroup ;
if ( ! test_OpenGroup_int ( tctx , p , & hGroup ) ) {
return false ;
}
return test_CloseGroup_int ( tctx , p , & hGroup ) ;
}
2015-02-26 23:03:36 +01:00
struct torture_suite * torture_rpc_clusapi ( TALLOC_CTX * mem_ctx )
{
struct torture_rpc_tcase * tcase ;
struct torture_suite * suite = torture_suite_create ( mem_ctx , " clusapi " ) ;
2015-03-06 13:34:44 +01:00
struct torture_test * test ;
2015-02-26 23:03:36 +01:00
tcase = torture_suite_add_rpc_iface_tcase ( suite , " clusapi " ,
& ndr_table_clusapi ) ;
torture_rpc_tcase_add_test ( tcase , " OpenCluster " ,
test_OpenCluster ) ;
torture_rpc_tcase_add_test ( tcase , " CloseCluster " ,
test_CloseCluster ) ;
2015-02-27 17:45:02 +01:00
torture_rpc_tcase_add_test ( tcase , " SetClusterName " ,
test_SetClusterName ) ;
torture_rpc_tcase_add_test ( tcase , " GetClusterName " ,
test_GetClusterName ) ;
torture_rpc_tcase_add_test ( tcase , " GetClusterVersion " ,
test_GetClusterVersion ) ;
2015-03-06 13:25:24 +01:00
torture_rpc_tcase_add_test ( tcase , " CreateEnum " ,
test_CreateEnum ) ;
2015-03-06 13:34:44 +01:00
torture_rpc_tcase_add_test ( tcase , " GetQuorumResource " ,
test_GetQuorumResource ) ;
torture_rpc_tcase_add_test ( tcase , " SetQuorumResource " ,
test_SetQuorumResource ) ;
torture_rpc_tcase_add_test ( tcase , " OpenResource " ,
test_OpenResource ) ;
torture_rpc_tcase_add_test ( tcase , " CloseResource " ,
test_CloseResource ) ;
torture_rpc_tcase_add_test ( tcase , " CreateResource " ,
test_CreateResource ) ;
torture_rpc_tcase_add_test ( tcase , " DeleteResource " ,
test_DeleteResource ) ;
torture_rpc_tcase_add_test ( tcase , " GetResourceState " ,
test_GetResourceState ) ;
torture_rpc_tcase_add_test ( tcase , " GetResourceId " ,
test_GetResourceId ) ;
torture_rpc_tcase_add_test ( tcase , " GetResourceType " ,
test_GetResourceType ) ;
test = torture_rpc_tcase_add_test ( tcase , " FailResource " ,
test_FailResource ) ;
test - > dangerous = true ;
torture_rpc_tcase_add_test ( tcase , " OnlineResource " ,
test_OnlineResource ) ;
test = torture_rpc_tcase_add_test ( tcase , " OfflineResource " ,
test_OfflineResource ) ;
test - > dangerous = true ;
2015-02-26 23:03:36 +01:00
2015-03-03 18:00:55 +01:00
torture_rpc_tcase_add_test ( tcase , " GetClusterVersion2 " ,
test_GetClusterVersion2 ) ;
2015-03-04 09:45:56 +01:00
torture_rpc_tcase_add_test ( tcase , " CreateResEnum " ,
test_CreateResEnum ) ;
2015-03-03 18:00:55 +01:00
2015-03-06 13:49:13 +01:00
tcase = torture_suite_add_rpc_iface_tcase ( suite , " node " ,
& ndr_table_clusapi ) ;
torture_rpc_tcase_add_test ( tcase , " OpenNode " ,
test_OpenNode ) ;
torture_rpc_tcase_add_test ( tcase , " CloseNode " ,
test_CloseNode ) ;
torture_rpc_tcase_add_test ( tcase , " GetNodeState " ,
test_GetNodeState ) ;
torture_rpc_tcase_add_test ( tcase , " GetNodeId " ,
test_GetNodeId ) ;
test = torture_rpc_tcase_add_test ( tcase , " PauseNode " ,
test_PauseNode ) ;
test - > dangerous = true ;
torture_rpc_tcase_add_test ( tcase , " ResumeNode " ,
test_ResumeNode ) ;
test = torture_rpc_tcase_add_test ( tcase , " EvictNode " ,
test_EvictNode ) ;
test - > dangerous = true ;
2015-03-06 13:50:45 +01:00
tcase = torture_suite_add_rpc_iface_tcase ( suite , " group " ,
& ndr_table_clusapi ) ;
torture_rpc_tcase_add_test ( tcase , " OpenGroup " ,
test_OpenGroup ) ;
torture_rpc_tcase_add_test ( tcase , " CloseGroup " ,
test_CloseGroup ) ;
2015-02-26 23:03:36 +01:00
return suite ;
}