2010-01-20 18:26:29 +01:00
/*-*- Mode: C; c-basic-offset: 8 -*-*/
2010-02-03 13:03:47 +01:00
/***
This file is part of systemd .
Copyright 2010 Lennart Poettering
systemd 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 2 of the License , or
( at your option ) any later version .
systemd 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 systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
2010-01-20 18:26:29 +01:00
# include <stdio.h>
# include <errno.h>
# include <string.h>
# include <unistd.h>
# include "manager.h"
int main ( int argc , char * argv [ ] ) {
Manager * m = NULL ;
2010-01-26 21:39:06 +01:00
Unit * a = NULL , * b = NULL , * c = NULL , * d = NULL , * e = NULL , * g = NULL , * h = NULL ;
2010-01-20 18:26:29 +01:00
Job * j ;
2010-01-27 00:15:56 +01:00
assert_se ( set_unit_path ( " test2 " ) > = 0 ) ;
2010-01-20 18:26:29 +01:00
2010-03-31 16:29:55 +02:00
assert_se ( manager_new ( & m ) > = 0 ) ;
2010-01-20 18:26:29 +01:00
2010-01-21 02:59:12 +01:00
printf ( " Load1: \n " ) ;
2010-01-26 21:39:06 +01:00
assert_se ( manager_load_unit ( m , " a.service " , & a ) = = 0 ) ;
assert_se ( manager_load_unit ( m , " b.service " , & b ) = = 0 ) ;
assert_se ( manager_load_unit ( m , " c.service " , & c ) = = 0 ) ;
manager_dump_units ( m , stdout , " \t " ) ;
2010-01-20 18:26:29 +01:00
printf ( " Test1: (Trivial) \n " ) ;
assert_se ( manager_add_job ( m , JOB_START , c , JOB_REPLACE , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-21 02:59:12 +01:00
printf ( " Load2: \n " ) ;
2010-01-20 18:26:29 +01:00
manager_clear_jobs ( m ) ;
2010-01-26 21:39:06 +01:00
assert_se ( manager_load_unit ( m , " d.service " , & d ) = = 0 ) ;
assert_se ( manager_load_unit ( m , " e.service " , & e ) = = 0 ) ;
manager_dump_units ( m , stdout , " \t " ) ;
2010-01-20 18:26:29 +01:00
printf ( " Test2: (Cyclic Order, Unfixable) \n " ) ;
2010-01-21 00:51:37 +01:00
assert_se ( manager_add_job ( m , JOB_START , d , JOB_REPLACE , false , & j ) = = - ENOEXEC ) ;
2010-01-20 18:26:29 +01:00
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-21 00:51:37 +01:00
printf ( " Test3: (Cyclic Order, Fixable, Garbage Collector) \n " ) ;
2010-01-20 18:26:29 +01:00
assert_se ( manager_add_job ( m , JOB_START , e , JOB_REPLACE , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-21 00:51:37 +01:00
printf ( " Test4: (Identical transaction) \n " ) ;
assert_se ( manager_add_job ( m , JOB_START , e , JOB_FAIL , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-21 02:59:12 +01:00
printf ( " Load3: \n " ) ;
2010-01-26 21:39:06 +01:00
assert_se ( manager_load_unit ( m , " g.service " , & g ) = = 0 ) ;
manager_dump_units ( m , stdout , " \t " ) ;
2010-01-21 00:51:37 +01:00
printf ( " Test5: (Colliding transaction, fail) \n " ) ;
assert_se ( manager_add_job ( m , JOB_START , g , JOB_FAIL , false , & j ) = = - EEXIST ) ;
printf ( " Test6: (Colliding transaction, replace) \n " ) ;
assert_se ( manager_add_job ( m , JOB_START , g , JOB_REPLACE , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-21 02:59:12 +01:00
printf ( " Test7: (Unmeargable job type, fail) \n " ) ;
assert_se ( manager_add_job ( m , JOB_STOP , g , JOB_FAIL , false , & j ) = = - EEXIST ) ;
printf ( " Test8: (Mergeable job type, fail) \n " ) ;
assert_se ( manager_add_job ( m , JOB_RESTART , g , JOB_FAIL , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
printf ( " Test9: (Unmeargable job type, replace) \n " ) ;
assert_se ( manager_add_job ( m , JOB_STOP , g , JOB_REPLACE , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
printf ( " Load4: \n " ) ;
2010-01-26 21:39:06 +01:00
assert_se ( manager_load_unit ( m , " h.service " , & h ) = = 0 ) ;
manager_dump_units ( m , stdout , " \t " ) ;
2010-01-21 02:59:12 +01:00
printf ( " Test10: (Unmeargable job type of auxiliary job, fail) \n " ) ;
assert_se ( manager_add_job ( m , JOB_START , h , JOB_FAIL , false , & j ) = = 0 ) ;
manager_dump_jobs ( m , stdout , " \t " ) ;
2010-01-20 18:26:29 +01:00
manager_free ( m ) ;
return 0 ;
}