All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.springframework.mock.web.MockMultipartHttpServletRequest Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2002-2024 the original author or authors.
 *
 * 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
 *
 *      https://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.springframework.mock.web;

import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.Enumeration;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Objects;

import jakarta.servlet.ServletContext;
import jakarta.servlet.ServletException;
import jakarta.servlet.http.Part;

import org.springframework.http.HttpHeaders;
import org.springframework.http.HttpMethod;
import org.springframework.lang.Nullable;
import org.springframework.util.Assert;
import org.springframework.util.LinkedMultiValueMap;
import org.springframework.util.MultiValueMap;
import org.springframework.web.multipart.MultipartException;
import org.springframework.web.multipart.MultipartFile;
import org.springframework.web.multipart.MultipartHttpServletRequest;

/**
 * Mock implementation of the
 * {@link org.springframework.web.multipart.MultipartHttpServletRequest} interface.
 *
 * 

As of Spring 6.0, this set of mocks is designed on a Servlet 6.0 baseline. * *

Useful for testing application controllers that access multipart uploads. * {@link MockMultipartFile} can be used to populate these mock requests with files. * * @author Juergen Hoeller * @author Eric Crampton * @author Arjen Poutsma * @since 2.0 * @see MockMultipartFile */ public class MockMultipartHttpServletRequest extends MockHttpServletRequest implements MultipartHttpServletRequest { private final MultiValueMap multipartFiles = new LinkedMultiValueMap<>(); /** * Create a new {@code MockMultipartHttpServletRequest} with a default * {@link MockServletContext}. * @see #MockMultipartHttpServletRequest(ServletContext) */ public MockMultipartHttpServletRequest() { this(null); } /** * Create a new {@code MockMultipartHttpServletRequest} with the supplied {@link ServletContext}. * @param servletContext the ServletContext that the request runs in * (may be {@code null} to use a default {@link MockServletContext}) */ public MockMultipartHttpServletRequest(@Nullable ServletContext servletContext) { super(servletContext); setMethod("POST"); setContentType("multipart/form-data"); } /** * Add a file to this request. The parameter name from the multipart * form is taken from the {@link MultipartFile#getName()}. * @param file multipart file to be added */ public void addFile(MultipartFile file) { Assert.notNull(file, "MultipartFile must not be null"); this.multipartFiles.add(file.getName(), file); } @Override public Iterator getFileNames() { return this.multipartFiles.keySet().iterator(); } @Override @Nullable public MultipartFile getFile(String name) { return this.multipartFiles.getFirst(name); } @Override public List getFiles(String name) { List multipartFiles = this.multipartFiles.get(name); return Objects.requireNonNullElse(multipartFiles, Collections.emptyList()); } @Override public Map getFileMap() { return this.multipartFiles.asSingleValueMap(); } @Override public MultiValueMap getMultiFileMap() { return new LinkedMultiValueMap<>(this.multipartFiles); } @Override @Nullable public String getMultipartContentType(String paramOrFileName) { MultipartFile file = getFile(paramOrFileName); if (file != null) { return file.getContentType(); } try { Part part = getPart(paramOrFileName); if (part != null) { return part.getContentType(); } } catch (ServletException | IOException ex) { // Should never happen (we're not actually parsing) throw new IllegalStateException(ex); } return null; } @Override public HttpMethod getRequestMethod() { String method = getMethod(); Assert.state(method != null, "Method must not be null"); return HttpMethod.valueOf(method); } @Override public HttpHeaders getRequestHeaders() { HttpHeaders headers = new HttpHeaders(); Enumeration headerNames = getHeaderNames(); while (headerNames.hasMoreElements()) { String headerName = headerNames.nextElement(); headers.put(headerName, Collections.list(getHeaders(headerName))); } return headers; } @Override @Nullable public HttpHeaders getMultipartHeaders(String paramOrFileName) { MultipartFile file = getFile(paramOrFileName); if (file != null) { HttpHeaders headers = new HttpHeaders(); if (file.getContentType() != null) { headers.add(HttpHeaders.CONTENT_TYPE, file.getContentType()); } return headers; } try { Part part = getPart(paramOrFileName); if (part != null) { HttpHeaders headers = new HttpHeaders(); for (String headerName : part.getHeaderNames()) { headers.put(headerName, new ArrayList<>(part.getHeaders(headerName))); } return headers; } } catch (Throwable ex) { throw new MultipartException("Could not access multipart servlet request", ex); } return null; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy