feat(apisix): add Cloudron package
- Implements Apache APISIX packaging for Cloudron platform. - Includes Dockerfile, CloudronManifest.json, and start.sh. - Configured to use Cloudron's etcd addon. 🤖 Generated with Gemini CLI Co-Authored-By: Gemini <noreply@google.com>
This commit is contained in:
134
CloudronPackages/APISIX/apisix-source/t/fuzzing/simple_http.py
Executable file
134
CloudronPackages/APISIX/apisix-source/t/fuzzing/simple_http.py
Executable file
@@ -0,0 +1,134 @@
|
||||
#! /usr/bin/env python
|
||||
|
||||
#
|
||||
# Licensed to the Apache Software Foundation (ASF) under one or more
|
||||
# contributor license agreements. See the NOTICE file distributed with
|
||||
# this work for additional information regarding copyright ownership.
|
||||
# The ASF licenses this file to You 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
|
||||
#
|
||||
# http://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.
|
||||
#
|
||||
|
||||
# This file provides a fuzzing test with most common plugins via plain HTTP request
|
||||
import http.client
|
||||
import json
|
||||
import random
|
||||
import threading
|
||||
from public import check_leak, LEAK_COUNT, run_test, connect_admin
|
||||
import yaml
|
||||
|
||||
REQ_PER_THREAD = 50
|
||||
THREADS_NUM = 10
|
||||
TOTOL_ROUTES = 50
|
||||
|
||||
def get_admin_key_from_yaml(yaml_file_path):
|
||||
with open(yaml_file_path, 'r') as file:
|
||||
yaml_data = yaml.safe_load(file)
|
||||
try:
|
||||
admin_key = yaml_data['deployment']['admin']['admin_key'][0]['key']
|
||||
return admin_key
|
||||
except KeyError:
|
||||
return None
|
||||
|
||||
def create_route():
|
||||
conf = json.dumps({
|
||||
"username": "jack",
|
||||
"plugins": {
|
||||
"jwt-auth": {
|
||||
"key": "user-key",
|
||||
"secret": "my-secret-key"
|
||||
}
|
||||
}
|
||||
})
|
||||
conn = connect_admin()
|
||||
key = get_admin_key_from_yaml('conf/config.yaml')
|
||||
if key is None:
|
||||
print("Key not found in the YAML file.")
|
||||
return
|
||||
key = key.replace('"', '')
|
||||
print("the key is", key)
|
||||
headers = {
|
||||
"X-API-KEY": key,
|
||||
}
|
||||
print("Request headers:", headers)
|
||||
conn.request("PUT", "/apisix/admin/consumers", conf,
|
||||
headers=headers)
|
||||
response = conn.getresponse()
|
||||
assert response.status <= 300, response.read()
|
||||
|
||||
for i in range(TOTOL_ROUTES):
|
||||
conn = connect_admin()
|
||||
i = str(i)
|
||||
conf = json.dumps({
|
||||
"uri": "/*",
|
||||
"host": "test" + i + ".com",
|
||||
"plugins": {
|
||||
"limit-count": {
|
||||
"count": LEAK_COUNT * REQ_PER_THREAD * THREADS_NUM,
|
||||
"time_window": 3600,
|
||||
},
|
||||
"jwt-auth": {
|
||||
},
|
||||
"proxy-rewrite": {
|
||||
"uri": "/" + i,
|
||||
"headers": {
|
||||
"X-APISIX-Route": "apisix-" + i
|
||||
}
|
||||
},
|
||||
"response-rewrite": {
|
||||
"headers": {
|
||||
"X-APISIX-Route": "$http_x_apisix_route"
|
||||
}
|
||||
},
|
||||
},
|
||||
"upstream": {
|
||||
"nodes": {
|
||||
"127.0.0.1:6666": 1
|
||||
},
|
||||
"type": "roundrobin"
|
||||
},
|
||||
})
|
||||
conn.request("PUT", "/apisix/admin/routes/" + i, conf,
|
||||
headers=headers)
|
||||
response = conn.getresponse()
|
||||
assert response.status <= 300, response.read()
|
||||
|
||||
def req():
|
||||
jwt_token = ("Bearer eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9."+
|
||||
"eyJrZXkiOiJ1c2VyLWtleSIsImV4cCI6MTg3OTMxODU0MX0."+
|
||||
"fNtFJnNmJgzbiYmGB0Yjvm-l6A6M4jRV1l4mnVFSYjs")
|
||||
route_id = str(random.randrange(TOTOL_ROUTES))
|
||||
conn = http.client.HTTPConnection("127.0.0.1", port=9080)
|
||||
conn.request("GET", "/",
|
||||
headers={
|
||||
"Host":"test" + route_id + ".com",
|
||||
"Authorization":jwt_token,
|
||||
})
|
||||
response = conn.getresponse()
|
||||
assert response.status == 200, response.read()
|
||||
hdr = response.headers["X-APISIX-Route"]
|
||||
assert hdr == "apisix-" + route_id, hdr
|
||||
|
||||
def run_in_thread():
|
||||
for i in range(REQ_PER_THREAD):
|
||||
req()
|
||||
|
||||
@check_leak
|
||||
def run():
|
||||
th = [threading.Thread(target=run_in_thread) for i in range(THREADS_NUM)]
|
||||
for t in th:
|
||||
t.start()
|
||||
for t in th:
|
||||
t.join()
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
run_test(create_route, run)
|
Reference in New Issue
Block a user