load("@io_bazel_rules_go//go:def.bzl", "go_library", "go_test")

package(default_visibility = ["//enterprise:__subpackages__"])

go_library(
    name = "store",
    srcs = ["store.go"],
    importpath = "github.com/buildbuddy-io/buildbuddy/enterprise/server/raft/store",
    deps = [
        "//enterprise/server/raft/bringup",
        "//enterprise/server/raft/client",
        "//enterprise/server/raft/config",
        "//enterprise/server/raft/constants",
        "//enterprise/server/raft/driver",
        "//enterprise/server/raft/events",
        "//enterprise/server/raft/keys",
        "//enterprise/server/raft/leasekeeper",
        "//enterprise/server/raft/listener",
        "//enterprise/server/raft/nodeliveness",
        "//enterprise/server/raft/rangecache",
        "//enterprise/server/raft/rangelease",
        "//enterprise/server/raft/rbuilder",
        "//enterprise/server/raft/registry",
        "//enterprise/server/raft/replica",
        "//enterprise/server/raft/sender",
        "//enterprise/server/raft/txn",
        "//enterprise/server/raft/usagetracker",
        "//enterprise/server/util/pebble",
        "//proto:raft_go_proto",
        "//proto:raft_service_go_proto",
        "//server/environment",
        "//server/interfaces",
        "//server/metrics",
        "//server/resources",
        "//server/util/alert",
        "//server/util/approxlru",
        "//server/util/canary",
        "//server/util/disk",
        "//server/util/grpc_server",
        "//server/util/log",
        "//server/util/proto",
        "//server/util/status",
        "//server/util/statusz",
        "@com_github_grpc_ecosystem_go_grpc_prometheus//:go-grpc-prometheus",
        "@com_github_hashicorp_serf//serf",
        "@com_github_jonboulle_clockwork//:clockwork",
        "@com_github_lni_dragonboat_v4//:dragonboat",
        "@com_github_lni_dragonboat_v4//config",
        "@com_github_lni_dragonboat_v4//raftio",
        "@com_github_lni_dragonboat_v4//statemachine",
        "@com_github_prometheus_client_golang//prometheus",
        "@org_golang_google_grpc//:grpc",
        "@org_golang_google_grpc//reflection",
        "@org_golang_x_sync//errgroup",
        "@org_golang_x_time//rate",
    ],
)

go_test(
    name = "store_test",
    srcs = ["store_test.go"],
    shard_count = 8,
    tags = ["block-network"],
    deps = [
        "//enterprise/server/raft/bringup",
        "//enterprise/server/raft/client",
        "//enterprise/server/raft/constants",
        "//enterprise/server/raft/filestore",
        "//enterprise/server/raft/keys",
        "//enterprise/server/raft/logger",
        "//enterprise/server/raft/rbuilder",
        "//enterprise/server/raft/replica",
        "//enterprise/server/raft/testutil",
        "//proto:raft_go_proto",
        "//server/testutil/testdigest",
        "//server/util/log",
        "//server/util/proto",
        "//server/util/status",
        "//server/util/testing/flags",
        "@com_github_jonboulle_clockwork//:clockwork",
        "@com_github_lni_dragonboat_v4//:dragonboat",
        "@com_github_stretchr_testify//require",
    ],
)
