2012-02-15 15:17:33 +01:00
/*
Unix SMB / CIFS implementation .
Test dbwrap_watch API
Copyright ( C ) Volker Lendecke 2012
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 "torture/proto.h"
# include "system/filesys.h"
# include "lib/dbwrap/dbwrap.h"
# include "lib/dbwrap/dbwrap_open.h"
# include "lib/dbwrap/dbwrap_watch.h"
# include "lib/util/util_tdb.h"
bool run_dbwrap_watch1 ( int dummy )
{
struct tevent_context * ev = NULL ;
struct messaging_context * msg = NULL ;
2016-07-12 15:59:56 +02:00
struct db_context * backend = NULL ;
2012-02-15 15:17:33 +01:00
struct db_context * db = NULL ;
const char * keystr = " key " ;
TDB_DATA key = string_term_tdb_data ( keystr ) ;
struct db_record * rec = NULL ;
struct tevent_req * req = NULL ;
NTSTATUS status ;
bool ret = false ;
2013-02-18 09:11:19 +01:00
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
2012-02-15 15:17:33 +01:00
if ( ev = = NULL ) {
fprintf ( stderr , " tevent_context_init failed \n " ) ;
goto fail ;
}
msg = messaging_init ( ev , ev ) ;
if ( msg = = NULL ) {
fprintf ( stderr , " messaging_init failed \n " ) ;
goto fail ;
}
2017-04-28 13:45:47 +02:00
backend = db_open ( msg , " test_watch.tdb " , 0 , TDB_CLEAR_IF_FIRST ,
2016-07-12 15:59:56 +02:00
O_CREAT | O_RDWR , 0644 , DBWRAP_LOCK_ORDER_1 ,
DBWRAP_FLAG_NONE ) ;
if ( backend = = NULL ) {
2012-02-15 15:17:33 +01:00
fprintf ( stderr , " db_open failed: %s \n " , strerror ( errno ) ) ;
goto fail ;
}
2016-07-12 15:59:56 +02:00
2018-08-16 11:25:54 +02:00
db = db_open_watched ( ev , & backend , msg ) ;
2016-07-12 15:59:56 +02:00
2012-02-15 15:17:33 +01:00
rec = dbwrap_fetch_locked ( db , db , key ) ;
if ( rec = = NULL ) {
fprintf ( stderr , " dbwrap_fetch_locked failed \n " ) ;
goto fail ;
}
2016-07-12 15:59:56 +02:00
req = dbwrap_watched_watch_send ( talloc_tos ( ) , ev , rec ,
( struct server_id ) { 0 } ) ;
2012-02-15 15:17:33 +01:00
if ( req = = NULL ) {
fprintf ( stderr , " dbwrap_record_watch_send failed \n " ) ;
goto fail ;
}
TALLOC_FREE ( rec ) ;
2014-04-29 14:10:04 +02:00
status = dbwrap_store_int32_bystring ( db , " different_key " , 1 ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
fprintf ( stderr , " dbwrap_store_int32 failed: %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
2012-06-14 20:30:16 +02:00
status = dbwrap_store_int32_bystring ( db , keystr , 1 ) ;
2012-02-15 15:17:33 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
fprintf ( stderr , " dbwrap_store_int32 failed: %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
if ( ! tevent_req_poll ( req , ev ) ) {
fprintf ( stderr , " tevent_req_poll failed \n " ) ;
goto fail ;
}
2017-07-01 08:27:57 +02:00
status = dbwrap_watched_watch_recv ( req , NULL , NULL ) ;
2012-02-15 15:17:33 +01:00
if ( ! NT_STATUS_IS_OK ( status ) ) {
fprintf ( stderr , " dbwrap_record_watch_recv failed: %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
2017-04-28 13:45:47 +02:00
( void ) unlink ( " test_watch.tdb " ) ;
2012-02-15 15:17:33 +01:00
ret = true ;
fail :
TALLOC_FREE ( req ) ;
TALLOC_FREE ( rec ) ;
TALLOC_FREE ( db ) ;
TALLOC_FREE ( msg ) ;
TALLOC_FREE ( ev ) ;
return ret ;
}
2017-04-28 13:58:48 +02:00
/*
* Make sure dbwrap_parse_record does not return NT_STATUS_OK on
* invalid data
*/
bool run_dbwrap_watch2 ( int dummy )
{
struct tevent_context * ev = NULL ;
struct messaging_context * msg = NULL ;
struct db_context * backend = NULL ;
struct db_context * db = NULL ;
const char * keystr = " key " ;
TDB_DATA key = string_term_tdb_data ( keystr ) ;
NTSTATUS status ;
bool ret = false ;
ev = samba_tevent_context_init ( talloc_tos ( ) ) ;
if ( ev = = NULL ) {
fprintf ( stderr , " tevent_context_init failed \n " ) ;
goto fail ;
}
msg = messaging_init ( ev , ev ) ;
if ( msg = = NULL ) {
fprintf ( stderr , " messaging_init failed \n " ) ;
goto fail ;
}
backend = db_open ( msg , " test_watch.tdb " , 0 , TDB_CLEAR_IF_FIRST ,
O_CREAT | O_RDWR , 0644 , DBWRAP_LOCK_ORDER_1 ,
DBWRAP_FLAG_NONE ) ;
if ( backend = = NULL ) {
fprintf ( stderr , " db_open failed: %s \n " , strerror ( errno ) ) ;
goto fail ;
}
/*
* Store invalid data ( from the dbwrap_watch point of view )
* directly into the backend database
*/
status = dbwrap_store_uint32_bystring ( backend , keystr , UINT32_MAX ) ;
if ( ! NT_STATUS_IS_OK ( status ) ) {
fprintf ( stderr , " dbwrap_store_uint32_bystring failed: %s \n " ,
nt_errstr ( status ) ) ;
goto fail ;
}
2018-08-16 11:25:54 +02:00
db = db_open_watched ( ev , & backend , msg ) ;
2017-04-28 13:58:48 +02:00
if ( db = = NULL ) {
fprintf ( stderr , " db_open_watched failed \n " ) ;
goto fail ;
}
backend = NULL ; /* open_watch talloc_moves backend */
status = dbwrap_parse_record ( db , key , NULL , NULL ) ;
if ( ! NT_STATUS_EQUAL ( status , NT_STATUS_NOT_FOUND ) ) {
fprintf ( stderr , " dbwrap_parse_record returned %s, expected "
" NT_STATUS_NOT_FOUND \n " , nt_errstr ( status ) ) ;
goto fail ;
}
( void ) unlink ( " test_watch.tdb " ) ;
ret = true ;
fail :
TALLOC_FREE ( db ) ;
TALLOC_FREE ( msg ) ;
TALLOC_FREE ( ev ) ;
return ret ;
}