I want to send below as a form-data in API Body for a PUT request:
- Upload a file(KEY) with "Error.png"(VALUE)
- Send text, "MyName"(KEY) with false(VALUE)
How to do this using REST-Assured
I want to send below as a form-data in API Body for a PUT request:
How to do this using REST-Assured
You need to set desired content type i.e "multipart/form-data" and add the multipart request specs to the request. Eg.
given()
.contentType("multipart/form-data")
.multiPart("file", "filename")
.multiPart("key", "value")
.when()
.put(endpoint);
Be sure to include a file object if you're doing a file upload. It should look like this:
given()
.contentType("multipart/form-data")
.multiPart("id", "123")
.multiPart("file", new File("./src/test/resources/test-file.txt"))
.post("api/endpoint")
.then()
...
Most of the times we need to convert image into readFileToByteArray.
String file = "/Users/Downloads/file.png";
byte[] fileContent = FileUtils.readFileToByteArray(new File(file));
RestAssured.baseURI = "Enter Base uri";
Response res = given()
.header("Accept", "application/json")
.header("Content-type", "multipart/form-data")
.formParam("token", "08bc73deff88dd3d44bb1bf65b55d4ff")
.multiPart("asset", "image/png", fileContent).when()
.post("api/endpoint");
System.out.println(res.getStatusCode());
System.out.println(res.jsonPath().prettify());
Please make sure the image mime type (specified in the example as "image/png").
// uploading image on click of upload button
//fileNames is state
const [fileNames,SetfileNames] = useState("");
const updatecsvfile = (e) => {
e.preventDefault();
const formdata = new FormData();
formdata.append("document", fileNames);
let verify = localStorage.getItem("_id");
console.log(verify);
console.log("Data", formdata);
// posting to api by formdata
axios
.post(`${SERVER_URL}/uploadDocument?_id=${docids}`, formdata)
.then((res) => {
console.log("res", res.data.status);
let Status = res.data.status;
if (Status === "success") {
window.$("#uploadproject_doc").modal("hide");
window.$("#doc_added").modal("show");
window.setTimeout(function () {
window.location.reload();
}, 2000);
} else {
alert("Details are already Exists");
}
});
};