/* * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You 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.apache.wicket.protocol.http.request; import java.util.Base64; import org.apache.wicket.core.request.mapper.CryptoMapper; import org.apache.wicket.markup.html.WebPage; import org.apache.wicket.markup.html.basic.SimplePage; import org.apache.wicket.mock.MockApplication; import org.apache.wicket.protocol.http.WebApplication; import org.apache.wicket.request.mapper.CompoundRequestMapper; import org.apache.wicket.util.crypt.ICrypt; import org.apache.wicket.util.crypt.ICryptFactory; import org.apache.wicket.util.tester.WicketTestCase; import org.junit.Test; /** * Simple test using the WicketTester */ public class CryptedUrlWebRequestCodingStrategyTest extends WicketTestCase { @Override protected WebApplication newApplication() { return new MockApplication() { @Override protected void init() { super.init(); // install crypto mapper to encrypt all application urls getSecuritySettings().setCryptFactory(new TestCryptFactory()); CompoundRequestMapper root = new CompoundRequestMapper(); root.add(new CryptoMapper(getRootRequestMapper(), this)); setRootRequestMapper(root); } }; } /** * */ @Test public void clientBidListPage() { WebPage page = new SimplePage(); WebPage p = (WebPage)tester.startPage(page); assertEquals(page.getClass(), p.getClass()); } /** * testRenderMyPagePost() */ @Test public void renderMyPagePost() { // start and render the test page tester.startPage(HomePage.class); tester.assertRenderedPage(HomePage.class); // POST tester.submitForm("form1"); tester.assertRenderedPage(HomePage.class); } /** * testRenderMyPageGet() */ @Test public void renderMyPageGet() { // start and render the test page tester.startPage(HomePage.class); tester.assertRenderedPage(HomePage.class); // POST tester.submitForm("form2"); tester.assertRenderedPage(HomePage.class); } /** * Simple obfuscation crypt for test purposes * * @author igor.vaynberg */ private static class TestCryptFactory implements ICryptFactory { @Override public ICrypt newCrypt() { return new ICrypt() { @Override public String decryptUrlSafe(String text) { return new String(Base64.getUrlDecoder().decode(text)); } @Override public String encryptUrlSafe(String plainText) { return new String(Base64.getUrlEncoder().encode(plainText.getBytes())); } @Override public void setKey(String key) { } }; } } }