/*
* JBoss, Home of Professional Open Source
* Copyright 2013, Red Hat Middleware LLC, and individual contributors
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
* http://www.apache.org/licenses/LICENSE-2.0
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.jboss.arquillian.warp.ftest.observer;
import static org.hamcrest.Matchers.containsString;
import static org.jboss.arquillian.warp.client.filter.http.HttpFilters.request;
import static org.junit.Assert.assertThat;
import java.io.File;
import java.net.URL;
import org.jboss.arquillian.container.test.api.Deployment;
import org.jboss.arquillian.container.test.api.RunAsClient;
import org.jboss.arquillian.drone.api.annotation.Drone;
import org.jboss.arquillian.junit.Arquillian;
import org.jboss.arquillian.test.api.ArquillianResource;
import org.jboss.arquillian.warp.Activity;
import org.jboss.arquillian.warp.Inspection;
import org.jboss.arquillian.warp.Warp;
import org.jboss.arquillian.warp.WarpTest;
import org.jboss.arquillian.warp.ftest.TestingServlet;
import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.asset.EmptyAsset;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.openqa.selenium.WebDriver;
/**
* @author Lukas Fryc
*/
@RunWith(Arquillian.class)
@WarpTest
@RunAsClient
public class TestRequestObserverFailureReporting {
@Drone
WebDriver browser;
@ArquillianResource
URL contextPath;
@Deployment
public static WebArchive createDeployment() {
return ShrinkWrap.create(WebArchive.class, "test.war")
.addClass(TestingServlet.class)
.addAsWebResource(new File("src/main/webapp/index.html"))
.addAsWebInfResource(EmptyAsset.INSTANCE, "beans.xml");
}
@Test
public void test_the_execution_should_report_failure_meaningfully() {
try {
Warp
.initiate(new Activity() {
public void perform() {
browser.navigate().to(contextPath + "index.html");
}
})
.observe(request().uri().contains("UNKNOWN"))
.inspect(new Inspection() {
private static final long serialVersionUID = 1L;
});
} catch (Exception e) {
String message = e.getMessage();
assertThat(message, containsString("The Warp failed"));
assertThat(message, containsString("uri.contains('UNKNOWN')"));
assertThat(message, containsString("GET /test/index.html"));
}
}
}