Coverage Report

Created: 2026-03-18 23:35

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/build/source/nativelink-store/src/default_store_factory.rs
Line
Count
Source
1
// Copyright 2024 The NativeLink Authors. All rights reserved.
2
//
3
// Licensed under the Functional Source License, Version 1.1, Apache 2.0 Future License (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
6
//
7
//    See LICENSE file for details
8
//
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12
// See the License for the specific language governing permissions and
13
// limitations under the License.
14
15
use core::pin::Pin;
16
use std::sync::Arc;
17
use std::time::SystemTime;
18
19
use futures::stream::FuturesOrdered;
20
use futures::{Future, TryStreamExt};
21
use nativelink_config::stores::{ExperimentalCloudObjectSpec, RedisMode, StoreSpec};
22
use nativelink_error::Error;
23
use nativelink_util::health_utils::HealthRegistryBuilder;
24
use nativelink_util::store_trait::{Store, StoreDriver};
25
26
use crate::azure_blob_store::AzureBlobStore;
27
use crate::completeness_checking_store::CompletenessCheckingStore;
28
use crate::compression_store::CompressionStore;
29
use crate::dedup_store::DedupStore;
30
use crate::existence_cache_store::ExistenceCacheStore;
31
use crate::fast_slow_store::FastSlowStore;
32
use crate::filesystem_store::FilesystemStore;
33
use crate::gcs_store::GcsStore;
34
use crate::grpc_store::GrpcStore;
35
use crate::memory_store::MemoryStore;
36
use crate::mongo_store::ExperimentalMongoStore;
37
use crate::noop_store::NoopStore;
38
use crate::ontap_s3_existence_cache_store::OntapS3ExistenceCache;
39
use crate::ontap_s3_store::OntapS3Store;
40
use crate::redis_store::RedisStore;
41
use crate::ref_store::RefStore;
42
use crate::s3_store::S3Store;
43
use crate::shard_store::ShardStore;
44
use crate::size_partitioning_store::SizePartitioningStore;
45
use crate::store_manager::StoreManager;
46
use crate::verify_store::VerifyStore;
47
48
type FutureMaybeStore<'a> = Box<dyn Future<Output = Result<Store, Error>> + Send + 'a>;
49
50
40
pub fn store_factory<'a>(
51
40
    backend: &'a StoreSpec,
52
40
    store_manager: &'a Arc<StoreManager>,
53
40
    maybe_health_registry_builder: Option<&'a mut HealthRegistryBuilder>,
54
40
) -> Pin<FutureMaybeStore<'a>> {
55
40
    Box::pin(async move {
56
40
        let store: Arc<dyn StoreDriver> = match backend {
57
37
            StoreSpec::Memory(spec) => MemoryStore::new(spec),
58
0
            StoreSpec::ExperimentalCloudObjectStore(spec) => match spec {
59
0
                ExperimentalCloudObjectSpec::Aws(aws_config) => {
60
0
                    S3Store::new(aws_config, SystemTime::now).await?
61
                }
62
0
                ExperimentalCloudObjectSpec::Ontap(ontap_config) => {
63
0
                    OntapS3Store::new(ontap_config, SystemTime::now).await?
64
                }
65
0
                ExperimentalCloudObjectSpec::Gcs(gcs_config) => {
66
0
                    GcsStore::new(gcs_config, SystemTime::now).await?
67
                }
68
0
                ExperimentalCloudObjectSpec::Azure(azure_config) => {
69
0
                    AzureBlobStore::new(azure_config, SystemTime::now).await?
70
                }
71
            },
72
0
            StoreSpec::RedisStore(spec) => {
73
0
                if spec.mode == RedisMode::Cluster {
  Branch (73:20): [True: 0, False: 0]
  Branch (73:20): [Folded - Ignored]
74
0
                    RedisStore::new_cluster(spec.clone()).await?
75
                } else {
76
0
                    RedisStore::new_standard(spec.clone()).await?
77
                }
78
            }
79
0
            StoreSpec::Verify(spec) => VerifyStore::new(
80
0
                spec,
81
0
                store_factory(&spec.backend, store_manager, None).await?,
82
            ),
83
0
            StoreSpec::Compression(spec) => CompressionStore::new(
84
0
                &spec.clone(),
85
0
                store_factory(&spec.backend, store_manager, None).await?,
86
0
            )?,
87
0
            StoreSpec::Dedup(spec) => DedupStore::new(
88
0
                spec,
89
0
                store_factory(&spec.index_store, store_manager, None).await?,
90
0
                store_factory(&spec.content_store, store_manager, None).await?,
91
0
            )?,
92
0
            StoreSpec::ExistenceCache(spec) => ExistenceCacheStore::new(
93
0
                spec,
94
0
                store_factory(&spec.backend, store_manager, None).await?,
95
            ),
96
3
            StoreSpec::OntapS3ExistenceCache(spec) => {
97
3
                OntapS3ExistenceCache::new(spec, SystemTime::now).await
?0
98
            }
99
0
            StoreSpec::CompletenessChecking(spec) => CompletenessCheckingStore::new(
100
0
                store_factory(&spec.backend, store_manager, None).await?,
101
0
                store_factory(&spec.cas_store, store_manager, None).await?,
102
            ),
103
0
            StoreSpec::FastSlow(spec) => FastSlowStore::new(
104
0
                spec,
105
0
                store_factory(&spec.fast, store_manager, None).await?,
106
0
                store_factory(&spec.slow, store_manager, None).await?,
107
            ),
108
0
            StoreSpec::Filesystem(spec) => <FilesystemStore>::new(spec).await?,
109
0
            StoreSpec::RefStore(spec) => RefStore::new(spec, Arc::downgrade(store_manager)),
110
0
            StoreSpec::SizePartitioning(spec) => SizePartitioningStore::new(
111
0
                spec,
112
0
                store_factory(&spec.lower_store, store_manager, None).await?,
113
0
                store_factory(&spec.upper_store, store_manager, None).await?,
114
            ),
115
0
            StoreSpec::Grpc(spec) => GrpcStore::new(spec).await?,
116
0
            StoreSpec::Noop(_) => NoopStore::new(),
117
0
            StoreSpec::ExperimentalMongo(spec) => ExperimentalMongoStore::new(spec.clone()).await?,
118
0
            StoreSpec::Shard(spec) => {
119
0
                let stores = spec
120
0
                    .stores
121
0
                    .iter()
122
0
                    .map(|store_spec| store_factory(&store_spec.store, store_manager, None))
123
0
                    .collect::<FuturesOrdered<_>>()
124
0
                    .try_collect::<Vec<_>>()
125
0
                    .await?;
126
0
                ShardStore::new(spec, stores)?
127
            }
128
        };
129
130
40
        if let Some(
health_registry_builder0
) = maybe_health_registry_builder {
  Branch (130:16): [True: 0, False: 40]
  Branch (130:16): [Folded - Ignored]
131
0
            store.clone().register_health(health_registry_builder);
132
40
        }
133
134
40
        Ok(Store::new(store))
135
40
    })
136
40
}