//Create a environment
environmentAPI.saveEnvironment( environment, permissions );
//Now we need to create the end point
PublishingEndPoint endpoint = new PublishingEndPoint();
endpoint.setServerName( new StringBuilder( "TestEndPoint" + String.valueOf( new Date().getTime() ) ) );
endpoint.setAddress( "127.0.0.1" );
endpoint.setPort( "999" );
endpoint.setProtocol( "http" );
endpoint.setAuthKey( new StringBuilder( PublicEncryptionFactory.encryptString( "1111" ) ) );
endpoint.setEnabled( true );
endpoint.setSending( false );//TODO: Shouldn't this be true as we are creating this end point to send bundles to another server..?
endpoint.setGroupId( environment.getId() );
//Save the endpoint.
publisherEndPointAPI.saveEndPoint( endpoint );
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++PUBLISH++++++++++++++++++++++++++++
//Getting test data
List<Contentlet> contentlets = contentletAPI.findAllContent( 0, 1 );
//Validations
assertNotNull( contentlets );
assertEquals( contentlets.size(), 1 );
//Preparing the url in order to push content
SimpleDateFormat dateFormat = new SimpleDateFormat( "yyyy-MM-dd" );
SimpleDateFormat timeFormat = new SimpleDateFormat( "H-m" );
String publishDate = dateFormat.format( new Date() );
String publishTime = timeFormat.format( new Date() );
String baseURL = "http://" + req.getServerName() + ":" + req.getServerPort() + "/DotAjaxDirector/com.dotcms.publisher.ajax.RemotePublishAjaxAction/cmd/publish/u/admin@dotcms.com/p/admin";
String completeURL = baseURL +
"?remotePublishDate=" + UtilMethods.encodeURIComponent( publishDate ) +
"&remotePublishTime=" + UtilMethods.encodeURIComponent( publishTime ) +
"&remotePublishExpireDate=" +
"&remotePublishExpireTime=" +
"&iWantTo=" + RemotePublishAjaxAction.DIALOG_ACTION_PUBLISH +
"&whoToSend=" + UtilMethods.encodeURIComponent( environment.getId() ) +
"&forcePush=false" +
"&assetIdentifier=" + UtilMethods.encodeURIComponent( contentlets.get( 0 ).getIdentifier() );
//Execute the call
URL publishUrl = new URL( completeURL );
String response = IOUtils.toString( publishUrl.openStream(), "UTF-8" );
//Validations
JSONObject jsonResponse = new JSONObject( response );
assertNotNull( contentlets );
assertEquals( jsonResponse.getInt( "errors" ), 0 );
assertEquals( jsonResponse.getInt( "total" ), 1 );
assertNotNull( jsonResponse.get( "bundleId" ) );
//Now that we have a bundle id
String bundleId = jsonResponse.getString( "bundleId" );
//First we need to verify if this bundle is in the queue job
List<PublishQueueElement> foundBundles = publisherAPI.getQueueElementsByBundleId( bundleId );
assertNotNull( foundBundles );
assertTrue( !foundBundles.isEmpty() );
/*
Now lets wait until it finished, by the way, we are expecting it to fail to publish as the end point does not exist.
Keep in mind the queue will try 3 times before to marked as failed to publish, so we have to wait a bit here....
*/
int x = 0;
do {
Thread.sleep( 3000 );
//Verify if it continues in the queue job
foundBundles = publisherAPI.getQueueElementsByBundleId( bundleId );
x++;
} while ( (foundBundles != null && !foundBundles.isEmpty()) && x < 200 );
//At this points should not be here anymore
foundBundles = publisherAPI.getQueueElementsByBundleId( bundleId );
assertTrue( foundBundles == null || foundBundles.isEmpty() );
//Get the audit records related to this bundle
PublishAuditStatus status = PublishAuditAPI.getInstance().getPublishAuditStatus( bundleId );
//We will be able to retry failed and successfully bundles
assertEquals( status.getStatus(), PublishAuditStatus.Status.FAILED_TO_PUBLISH ); //Remember, we are expecting this to fail
//Get current status dates
Date initialCreationDate = status.getCreateDate();
Date initialUpdateDate = status.getStatusUpdated();
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++++++++++++RETRY++++++++++++++++++++++++++++++
//Now we can try the retry
req = ServletTestRunner.localRequest.get();
baseURL = "http://" + req.getServerName() + ":" + req.getServerPort() + "/DotAjaxDirector/com.dotcms.publisher.ajax.RemotePublishAjaxAction/cmd/retry/u/admin@dotcms.com/p/admin";
completeURL = baseURL + "?bundlesIds=" + UtilMethods.encodeURIComponent( bundleId );
//Execute the call
URL retryUrl = new URL( completeURL );
response = IOUtils.toString( retryUrl.openStream(), "UTF-8" );//We can expect something like "Bundle id: <strong>1193e3eb-3ccd-496e-8995-29a9fcc48cbd</strong> added successfully to Publishing Queue."
//Validations
assertNotNull( response );
assertTrue( response.contains( bundleId ) );
assertTrue( response.contains( "added successfully to" ) );
//And should be back to the queue job
foundBundles = publisherAPI.getQueueElementsByBundleId( bundleId );
assertNotNull( foundBundles );
assertTrue( !foundBundles.isEmpty() );
//Get current status dates
status = PublishAuditAPI.getInstance().getPublishAuditStatus( bundleId );//Get the audit records related to this bundle
Date latestCreationDate = status.getCreateDate();
Date latestUpdateDate = status.getStatusUpdated();
//Validations
assertNotSame( initialCreationDate, latestCreationDate );
assertNotSame( initialUpdateDate, latestUpdateDate );
assertTrue( initialCreationDate.before( latestCreationDate ) );
assertTrue( initialUpdateDate.before( latestUpdateDate ) );
//+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
//++++++++++++++++++++SIMULATE AN END POINT++++++++++++++++++++++++
/*
And finally lets try to simulate a end point sending directly an already created bundle file to
the api/bundlePublisher/publish service
*/
//Create a receiving end point
PublishingEndPoint receivingFromEndpoint = new PublishingEndPoint();
receivingFromEndpoint.setServerName( new StringBuilder( "TestReceivingEndPoint" + String.valueOf( new Date().getTime() ) ) );
receivingFromEndpoint.setAddress( req.getServerName() );
receivingFromEndpoint.setPort( String.valueOf( req.getServerPort() ) );
receivingFromEndpoint.setProtocol( "http" );
receivingFromEndpoint.setAuthKey( new StringBuilder( PublicEncryptionFactory.encryptString( "1111" ) ) );
receivingFromEndpoint.setEnabled( true );
receivingFromEndpoint.setSending( true );//TODO: Shouldn't this be false as we are creating this end point to receive bundles from another server..?
receivingFromEndpoint.setGroupId( environment.getId() );
//Save the endpoint.
publisherEndPointAPI.saveEndPoint( receivingFromEndpoint );
//Find the bundle
Bundle bundle = APILocator.getBundleAPI().getBundleById( bundleId );
PublisherConfig basicConfig = new PublisherConfig();
basicConfig.setId( bundleId );
File bundleRoot = BundlerUtil.getBundleRoot( basicConfig );
File bundleFile = new File( bundleRoot + File.separator + ".." + File.separator + bundle.getId() + ".tar.gz" );
//lets wait one minute
Thread.sleep( 60000 );
assertTrue( bundleFile.exists() );
//Rename the bundle file
String newBundleId = UUID.randomUUID().toString();
File newBundleFile = new File( bundleRoot + File.separator + ".." + File.separator + newBundleId + ".tar.gz" );
Boolean success = bundleFile.renameTo( newBundleFile );
assertTrue( success );
assertTrue( newBundleFile.exists() );
//Prepare the post request
ClientConfig cc = new DefaultClientConfig();
Client client = Client.create( cc );
FormDataMultiPart form = new FormDataMultiPart();
form.field( "AUTH_TOKEN", PublicEncryptionFactory.encryptString( (PublicEncryptionFactory.decryptString( receivingFromEndpoint.getAuthKey().toString() )) ) );
form.field( "GROUP_ID", UtilMethods.isSet( receivingFromEndpoint.getGroupId() ) ? receivingFromEndpoint.getGroupId() : receivingFromEndpoint.getId() );
form.field( "BUNDLE_NAME", bundle.getName() );
form.field( "ENDPOINT_ID", receivingFromEndpoint.getId() );
form.bodyPart( new FileDataBodyPart( "bundle", newBundleFile, MediaType.MULTIPART_FORM_DATA_TYPE ) );
//Sending bundle to endpoint
WebResource resource = client.resource( receivingFromEndpoint.toURL() + "/api/bundlePublisher/publish" );
ClientResponse clientResponse = resource.type( MediaType.MULTIPART_FORM_DATA ).post( ClientResponse.class, form );
//Validations
assertEquals( clientResponse.getClientResponseStatus().getStatusCode(), HttpStatus.SC_OK );
//Get current status dates