我正在尝试使用 REST 保证来测试我的登录/注销功能。是否可以进行 REST 有保证的测试,先发布登录然后发布注销?如果没有,我该如何正确测试它?
问问题
6621 次
4 回答
3
只需发送两个post()和一个assert() / expect():
import org.junit.Assert;
import org.junit.Test;
import static org.hamcrest.Matchers.*;
import static com.jayway.restassured.RestAssured.*;
@Test
public void loginAndLogout(){
final String login = randomLogin();
// First post to login()
given()
.queryParam("login", login)
.queryParam("password", randomPassword())
.when().post("/login/");
// Second post to logout() with an assert
expect().statusCode(200)
.given()
.when().post("/logout/");
}
于 2014-07-17T11:35:08.610 回答
0
您的登录 api 调用是否会导致某种身份验证令牌在后续请求中重用?如果是这样,我将这些视为单独的放心调用,以对其进行全面测试。
(登录焦点)
- 向 /login api 发出 RestAssured 调用。保存返回的身份验证令牌。
- 使用保存的令牌,向系统中需要在第一步中进行身份验证的另一个 API 发出 RestAssured 调用。这确认身份验证令牌有效。
(注销焦点)
- 使用保存的令牌向 /logout api 发出 RestAssured 调用。
- 重复第 2 步并确认此请求现在失败,因为登录令牌在第 3 步之后不再有效。
于 2018-10-05T20:25:34.440 回答
0
你也试试这个:
使用 xyzjson 名称创建您的 JSON 文件,并将您的后有效负载数据保存在该文件中并使用以下代码。
Response rep = given()
.headers
.(headers)
.accept(contentType.json)
.body (xyzjson)
.when()
.post(someURL);
Assert.assertTrue(rep.StatusCode() == HttpStatus.SC_Ok);
于 2018-09-07T20:35:37.753 回答