KEYCLOAK-3297 Add test for Access-Control-Expose-Headers
This commit is contained in:
parent
3a13981d3f
commit
b86079c589
6 changed files with 20 additions and 3 deletions
|
@ -97,6 +97,7 @@
|
|||
</div>
|
||||
|
||||
</div>
|
||||
<div id="headers">{{headers}}</div>
|
||||
</div>
|
||||
</body>
|
||||
</html>
|
||||
|
|
|
@ -73,9 +73,9 @@ module.controller('GlobalCtrl', function($scope, $http) {
|
|||
$scope.realm = [];
|
||||
$scope.version = [];
|
||||
$scope.reloadData = function() {
|
||||
$http.get(getAppServerUrl("localhost-db") + "/cors-database/products").success(function(data) {
|
||||
$http.get(getAppServerUrl("localhost-db") + "/cors-database/products").success(function(data, status, headers, config) {
|
||||
$scope.products = angular.fromJson(data);
|
||||
|
||||
$scope.headers = headers();
|
||||
});
|
||||
|
||||
};
|
||||
|
|
|
@ -19,9 +19,11 @@ package org.keycloak.example.oauth;
|
|||
|
||||
import org.jboss.resteasy.annotations.cache.NoCache;
|
||||
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import javax.ws.rs.GET;
|
||||
import javax.ws.rs.Path;
|
||||
import javax.ws.rs.Produces;
|
||||
import javax.ws.rs.core.Context;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
|
@ -31,6 +33,10 @@ import java.util.List;
|
|||
*/
|
||||
@Path("products")
|
||||
public class ProductService {
|
||||
|
||||
@Context
|
||||
private HttpServletResponse response;
|
||||
|
||||
@GET
|
||||
@Produces("application/json")
|
||||
@NoCache
|
||||
|
@ -39,6 +45,8 @@ public class ProductService {
|
|||
rtn.add("iphone");
|
||||
rtn.add("ipad");
|
||||
rtn.add("ipod");
|
||||
|
||||
response.addHeader("X-Custom1", "some-value");
|
||||
return rtn;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,5 +5,6 @@
|
|||
"auth-server-url": "http://localhost-auth:8180/auth",
|
||||
"bearer-only" : true,
|
||||
"ssl-required": "external",
|
||||
"enable-cors": true
|
||||
"enable-cors": true,
|
||||
"cors-exposed-headers": "X-Custom1"
|
||||
}
|
||||
|
|
|
@ -66,6 +66,8 @@ public class AngularCorsProductTestApp extends AbstractPageWithInjectedUrl {
|
|||
|
||||
@FindBy(id = "output")
|
||||
private WebElement outputArea;
|
||||
@FindBy(id = "headers")
|
||||
private WebElement headers;
|
||||
|
||||
public void reloadData() {
|
||||
reloadDataButton.click();
|
||||
|
@ -99,5 +101,9 @@ public class AngularCorsProductTestApp extends AbstractPageWithInjectedUrl {
|
|||
return outputArea;
|
||||
}
|
||||
|
||||
public WebElement getHeaders() {
|
||||
return headers;
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -94,6 +94,7 @@ public abstract class AbstractCorsExampleAdapterTest extends AbstractExampleAdap
|
|||
waitUntilElement(angularCorsProductPage.getOutput()).text().contains("iphone");
|
||||
waitUntilElement(angularCorsProductPage.getOutput()).text().contains("ipad");
|
||||
waitUntilElement(angularCorsProductPage.getOutput()).text().contains("ipod");
|
||||
waitUntilElement(angularCorsProductPage.getHeaders()).text().contains("\"x-custom1\":\"some-value\"");
|
||||
|
||||
angularCorsProductPage.loadRoles();
|
||||
waitUntilElement(angularCorsProductPage.getOutput()).text().contains("user");
|
||||
|
|
Loading…
Reference in a new issue