/* * 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.axis2.webapp; import static com.google.common.truth.Truth.assertThat; import org.junit.Before; import org.junit.Rule; import org.junit.Test; public class AxisAdminServletITCase { @Rule public Axis2WebTester tester = new Axis2WebTester(); @Before public void setUp() { tester.beginAt("/axis2-admin/"); tester.setTextField("userName", "admin"); tester.setTextField("password", "axis2"); tester.submit(); } @Test public void testAvailableServices() { tester.clickLinkWithText("Available Services"); tester.assertMatch("Service EPR : http://localhost:[0-9]+/axis2/services/Version"); } /** * Tests that the admin console is not vulnerable to session fixation attacks. This tests * attempts to log in with an existing session. This should result in a new session with a * different session ID. */ @Test public void loginInvalidatesExistingSession() { String sessionId = tester.getSessionId(); assertThat(sessionId).isNotNull(); tester.gotoPage("/axis2-admin/welcome"); tester.setTextField("userName", "admin"); tester.setTextField("password", "axis2"); tester.submit(); assertThat(tester.getSessionId()).isNotEqualTo(sessionId); } }