001package org.apache.maven.wagon.providers.http; 002 003/* 004 * Licensed to the Apache Software Foundation (ASF) under one 005 * or more contributor license agreements. See the NOTICE file 006 * distributed with this work for additional information 007 * regarding copyright ownership. The ASF licenses this file 008 * to you under the Apache License, Version 2.0 (the 009 * "License"); you may not use this file except in compliance 010 * with the License. You may obtain a copy of the License at 011 * 012 * http://www.apache.org/licenses/LICENSE-2.0 013 * 014 * Unless required by applicable law or agreed to in writing, 015 * software distributed under the License is distributed on an 016 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 017 * KIND, either express or implied. See the License for the 018 * specific language governing permissions and limitations 019 * under the License. 020 */ 021 022import org.apache.maven.wagon.Wagon; 023import org.apache.maven.wagon.shared.http.HttpConfiguration; 024import org.apache.maven.wagon.shared.http.HttpMethodConfiguration; 025import org.eclipse.jetty.server.Server; 026import org.eclipse.jetty.server.ServerConnector; 027import org.eclipse.jetty.util.ssl.SslContextFactory; 028 029public class HttpsWagonPreemptiveTest 030 extends HttpWagonTest 031{ 032 protected String getProtocol() 033 { 034 return "https"; 035 } 036 037 protected ServerConnector addConnector( Server server ) 038 { 039 System.setProperty( "javax.net.ssl.trustStore", 040 getTestFile( "src/test/resources/ssl/keystore" ).getAbsolutePath() ); 041 SslContextFactory sslContextFactory = new SslContextFactory(); 042 sslContextFactory.setKeyStorePath( getTestPath( "src/test/resources/ssl/keystore" ) ); 043 sslContextFactory.setKeyStorePassword( "wagonhttp" ); 044 sslContextFactory.setKeyManagerPassword( "wagonhttp" ); 045 sslContextFactory.setTrustStorePath( getTestPath( "src/test/resources/ssl/keystore" ) ); 046 sslContextFactory.setTrustStorePassword( "wagonhttp" ); 047 ServerConnector serverConnector = new ServerConnector( server, sslContextFactory ); 048 server.addConnector( serverConnector ); 049 return serverConnector; 050 } 051 052 @Override 053 protected Wagon getWagon() 054 throws Exception 055 { 056 HttpWagon wagon = (HttpWagon) super.getWagon(); 057 wagon.setHttpConfiguration( 058 new HttpConfiguration().setAll( new HttpMethodConfiguration().setUsePreemptive( true ) ) ); 059 return wagon; 060 } 061 062 @Override 063 protected boolean supportPreemptiveAuthenticationPut() 064 { 065 return true; 066 } 067 068 @Override 069 protected boolean supportPreemptiveAuthenticationGet() 070 { 071 return true; 072 } 073 074 @Override 075 protected boolean supportProxyPreemptiveAuthentication() 076 { 077 return true; 078 } 079 080 @Override 081 protected boolean assertOnTransferProgress() 082 { 083 return false; 084 } 085}