mirror of
https://github.com/status-im/libp2p-test-plans.git
synced 2025-01-16 09:54:37 +00:00
53ff8b5db1
This project includes the following components: - `terraform/`: a Terraform scripts to provision infrastructure - `impl/`: implementations of the [libp2p perf protocol](https://github.com/libp2p/specs/blob/master/perf/perf.md) running on top of e.g. go-libp2p, rust-libp2p or Go's std-library https stack - `runner/`: a set of scripts building and running the above implementations on the above infrastructure, reporting the results in `benchmark-results.json` Benchmark results can be visualized with https://observablehq.com/@mxinden-workspace/libp2p-performance-dashboard. Co-authored-by: Marco Munizaga <git@marcopolo.io> Co-authored-by: Marten Seemann <martenseemann@gmail.com> Co-authored-by: Piotr Galar <piotr.galar@gmail.com>
108 lines
2.9 KiB
HCL
108 lines
2.9 KiB
HCL
data "archive_file" "cleanup" {
|
|
type = "zip"
|
|
source_file = "${path.module}/files/cleanup.py"
|
|
output_path = "${path.module}/files/cleanup.zip"
|
|
}
|
|
|
|
resource "aws_lambda_function" "cleanup" {
|
|
filename = data.archive_file.cleanup.output_path
|
|
source_code_hash = data.archive_file.cleanup.output_base64sha256
|
|
function_name = "perf-cleanup"
|
|
role = aws_iam_role.cleanup.arn
|
|
handler = "cleanup.lambda_handler"
|
|
runtime = "python3.9"
|
|
memory_size = 128
|
|
timeout = 30
|
|
|
|
environment {
|
|
variables = {
|
|
REGIONS = jsonencode(var.regions)
|
|
TAGS = jsonencode(var.tags)
|
|
MAX_AGE_MINUTES = 50
|
|
}
|
|
}
|
|
}
|
|
|
|
resource "aws_cloudwatch_log_group" "cleanup" {
|
|
name = "/aws/lambda/${aws_lambda_function.cleanup.function_name}"
|
|
retention_in_days = 7
|
|
}
|
|
|
|
resource "aws_cloudwatch_event_rule" "cleanup" {
|
|
name = "perf-cleanup-rule"
|
|
schedule_expression = "cron(37 * * * ? *)" # 00:37, 01:37, 02:37, ..., 23:37
|
|
}
|
|
|
|
resource "aws_cloudwatch_event_target" "cleanup" {
|
|
rule = aws_cloudwatch_event_rule.cleanup.name
|
|
arn = aws_lambda_function.cleanup.arn
|
|
}
|
|
|
|
resource "aws_lambda_permission" "cleanup" {
|
|
statement_id = "AllowExecutionFromCloudWatch"
|
|
action = "lambda:InvokeFunction"
|
|
function_name = aws_lambda_function.cleanup.function_name
|
|
principal = "events.amazonaws.com"
|
|
source_arn = aws_cloudwatch_event_rule.cleanup.arn
|
|
}
|
|
|
|
data "aws_iam_policy_document" "cleanup_assume_role" {
|
|
statement {
|
|
actions = ["sts:AssumeRole"]
|
|
|
|
principals {
|
|
type = "Service"
|
|
identifiers = ["lambda.amazonaws.com"]
|
|
}
|
|
}
|
|
}
|
|
|
|
resource "aws_iam_role" "cleanup" {
|
|
name = "perf-cleanup-lambda-role"
|
|
assume_role_policy = data.aws_iam_policy_document.cleanup_assume_role.json
|
|
}
|
|
|
|
data "aws_iam_policy_document" "cleanup" {
|
|
statement {
|
|
actions = ["ec2:DescribeInstances", "ec2:DescribeTags", "ec2:DescribeKeyPairs"]
|
|
resources = ["*"]
|
|
effect = "Allow"
|
|
}
|
|
|
|
statement {
|
|
actions = ["ec2:TerminateInstances", "ec2:DeleteKeyPair"]
|
|
resources = ["*"]
|
|
effect = "Allow"
|
|
|
|
dynamic "condition" {
|
|
for_each = var.tags
|
|
|
|
content {
|
|
test = "StringEquals"
|
|
variable = "ec2:ResourceTag/${condition.key}"
|
|
values = [condition.value]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
resource "aws_iam_role_policy" "cleanup" {
|
|
name = "perf-cleanup-lamda-policy"
|
|
role = aws_iam_role.cleanup.name
|
|
policy = data.aws_iam_policy_document.cleanup.json
|
|
}
|
|
|
|
data "aws_iam_policy_document" "cleanup_logging" {
|
|
statement {
|
|
actions = ["logs:CreateLogStream", "logs:PutLogEvents"]
|
|
resources = ["${aws_cloudwatch_log_group.cleanup.arn}*"]
|
|
effect = "Allow"
|
|
}
|
|
}
|
|
|
|
resource "aws_iam_role_policy" "cleanup_logging" {
|
|
name = "perf-lambda-logging"
|
|
role = aws_iam_role.cleanup.name
|
|
policy = data.aws_iam_policy_document.cleanup_logging.json
|
|
}
|