assertThat( topology.getName(), is( "topology2" ) );
assertThat( topology.getTimestamp(), is( file.lastModified() ) );
assertThat( topology.getServices().size(), is( 4 ) );
assertThat( topology.getProviders().size(), is( 2 ) );
Service webhdfsService = topology.getService( "WEBHDFS", null );
assertThat( webhdfsService, notNullValue() );
assertThat( webhdfsService.getRole(), is( "WEBHDFS" ) );
assertThat( webhdfsService.getName(), nullValue() );
assertThat( webhdfsService.getUrls().size(), is( 2 ) );
assertThat( webhdfsService.getUrls(), hasItem( "http://host1:50070/webhdfs" ) );
assertThat( webhdfsService.getUrls(), hasItem( "http://host2:50070/webhdfs" ) );
Service webhcatService = topology.getService( "WEBHCAT", null );
assertThat( webhcatService, notNullValue() );
assertThat( webhcatService.getRole(), is( "WEBHCAT" ) );
assertThat( webhcatService.getName(), nullValue() );
assertThat( webhcatService.getUrls().size(), is( 1 ) );
assertThat( webhcatService.getUrls(), hasItem( "http://host:50111/templeton" ) );
Service oozieService = topology.getService( "OOZIE", null );
assertThat( oozieService, notNullValue() );
assertThat( oozieService.getRole(), is( "OOZIE" ) );
assertThat( oozieService.getName(), nullValue() );
assertThat( webhcatService.getUrls().size(), is( 1 ) );
assertThat( oozieService.getUrls(), hasItem( "http://host:11000/oozie" ) );
Service hiveService = topology.getService( "HIVE", null );
assertThat( hiveService, notNullValue() );
assertThat( hiveService.getRole(), is( "HIVE" ) );
assertThat( hiveService.getName(), nullValue() );
assertThat( webhcatService.getUrls().size(), is( 1 ) );
assertThat( hiveService.getUrls(), hasItem( "http://host:10000" ) );
Provider authenticationProvider = topology.getProvider( "authentication", "ShiroProvider" );
assertThat( authenticationProvider, notNullValue() );
assertThat( authenticationProvider.isEnabled(), is( true ) );
assertThat( authenticationProvider.getRole(), is( "authentication" ) );