LocustIO始终为所有Post API调用返回内部服务器错误

时间:2018-03-28 11:14:39

标签: python load-testing internal-server-error locust

我使用Locust运行负载测试,令我惊讶的是我尝试从它调用的所有POST API都返回"内部服务器错误 - 500",但是如果我运行相同的API来自JMeter,他们运行良好。我检查并在每次通话结束时看到像LocustIO prepends和撇号。这是一个截屏 Locust Failure UI

这是我的设置代码:

from locust import HttpLocust, TaskSet, task

class justTestApi(TaskSet):

    @task(1)
    def accountInquiry(self):
        self.client.post("/users", {
    "id": 1,
    "name": "Leanne Graham",
    "username": "Bret",
    "email": "Sincere@april.biz",
    "address": {
      "street": "Kulas Light",
      "suite": "Apt. 556",
      "city": "Gwenborough",
      "zipcode": "92998-3874",
      "geo": {
        "lat": "-37.3159",
        "lng": "81.1496"
      }
    },
    "phone": "1-770-736-8031 x56442",
    "website": "hildegard.org",
    "company": {
      "name": "Romaguera-Crona",
      "catchPhrase": "Multi-layered client-server neural-net",
      "bs": "harness real-time e-markets"
    }
  });

class WebsiteUser(HttpLocust):
    task_set = justTestApi
    min_wait = 5000
    max_wait = 9000
    host = "https://jsonplaceholder.typicode.com"
    stop_timeout = 200

1 个答案:

答案 0 :(得分:-1)

最后让它使用本教程 - https://andrew-jones.com/blog/load-testing-with-locust/。这是设置在尝试测试后休息呼叫时的样子。我读到一个论点,即LocustIO不能用来测试https,这个测试就是因为这个问题出了问题。它也可以用来测试https。

from locust import HttpLocust, TaskSet, task

json = """
[{
  userId: 1,
  id: 1,
  title: "quidem molestiae enim"
}]
"""

class MyTaskSet(TaskSet):
    @task(1)
    def send(l):
        l.client.post("/albums", json) 

class MyLocust(HttpLocust):
    task_set = MyTaskSet
    min_wait = 5000
    max_wait = 15000
    # host = "http://www.somaku.com"
    host = "https://jsonplaceholder.typicode.com"
    stop_timeout = 200