diff options
| author | mrlolthe1st <[email protected]> | 2025-10-10 10:46:06 +0300 | 
|---|---|---|
| committer | mrlolthe1st <[email protected]> | 2025-10-10 11:01:48 +0300 | 
| commit | f5397eb7b72b0fa2a05676c524c0c76a2afed3bc (patch) | |
| tree | 2962505227c48975a8ac984afb900b53ca4a1251 /yql/essentials/core/layers/layers_ut.cpp | |
| parent | b65c1eb471dda662f77af9de9b97ab3a6582ba21 (diff) | |
YQL-20072: Init pragma Layer and yt.LayerCaches
commit_hash:9199da15c695cf5c8a492750a8bcfbb0f31c0b34
Diffstat (limited to 'yql/essentials/core/layers/layers_ut.cpp')
| -rw-r--r-- | yql/essentials/core/layers/layers_ut.cpp | 167 | 
1 files changed, 167 insertions, 0 deletions
| diff --git a/yql/essentials/core/layers/layers_ut.cpp b/yql/essentials/core/layers/layers_ut.cpp new file mode 100644 index 00000000000..4d9c31bd323 --- /dev/null +++ b/yql/essentials/core/layers/layers_ut.cpp @@ -0,0 +1,167 @@ +#include <library/cpp/testing/unittest/registar.h> + +#include "layers.h" + +using namespace NYql::NLayers; + +class TDummyRemote : public IRemoteLayerProvider { +public: +    NThreading::TFuture<TLayerInfo> GetLayerInfo(const TMaybe<TString>& parent, const TString& url) const override { +        if (parent) { +            throw yexception() << "Can't use parent here"; +        } +        if (url == "dummy://1") { +            return NThreading::MakeFuture<TLayerInfo>(TLayerInfo{ +                .Locations={ +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="2" +                    }, +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="3" +                    } +                }, +                .Parent=TKey({}, "dummy://2") +            }); +        } + +        if (url == "dummy://2") { +            return NThreading::MakeFuture<TLayerInfo>(TLayerInfo{ +                .Locations={ +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="3" +                    }, +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="4" +                    } +                }, +                .Parent=TKey({}, "dummy://3") +            }); +        } + +        if (url == "dummy://3") { +            return NThreading::MakeFuture<TLayerInfo>(TLayerInfo{ +                .Locations={ +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="1" +                    }, +                    TLocation{ +                        .System="yt", +                        .Cluster="hahn", +                        .Path="2" +                    } +                } +            }); +        } +        throw yexception() << "???"; +    } +}; + +class TDummyIntegration : public ILayersIntegration { +public: + +    TMaybe<TVector<TLocation>> ResolveLayers(const TVector<TKey>& order, const TString& cluster, NYql::TExprContext& ctx) const override { +        TVector<std::pair<TKey, const TLayerInfo*>> infos; +        infos.reserve(order.size()); +        for (auto &e: order) { +            infos.emplace_back(e, Data_.FindPtr(e)); +        } +        auto layers = RemoveDuplicates(infos, "yt", cluster, ctx); +        if (!layers) { +            return {}; +        } +        TVector<TLocation> result; +        result.reserve(layers->size()); +        for (auto &e: *layers) { +            result.emplace_back(e.front()); +        } +        return result; +    } + +    bool UpdateLayerCache(const TKey& key, const TLayerInfo& layer, NYql::TExprContext&) override { +        Data_.emplace(key, layer); +        return true; +    } + +    bool UpdateLayerLocations(const TKey&, TVector<TLocation>&&, NYql::TExprContext&) override { +        return true; +    } + +    void RemoveLayerByName(const TString& ) override { + +    } + +private: +    THashMap<TKey, TLayerInfo> Data_; +}; + +ILayersRegistryPtr MakeRegistry() { +    return MakeLayersRegistry({ +            {"dummy", MakeIntrusive<TDummyRemote>()} +        }, +        { +            {"yt", MakeIntrusive<TDummyIntegration>()} +        } +    ); +}; + +Y_UNIT_TEST_SUITE(TLayers) { +    Y_UNIT_TEST(InvariantsTest) { +        auto reg = MakeRegistry(); +        auto ctx = NYql::TExprContext(); +        UNIT_ASSERT(reg->AddLayer("11", {}, {}, ctx)); +        UNIT_ASSERT(!reg->AddLayer("11", {}, {}, ctx)); +        UNIT_ASSERT(reg->AddLayer("1", {}, {}, ctx)); + +        UNIT_ASSERT(reg->AddLayer("Pen", {}, {}, ctx)); +        UNIT_ASSERT(reg->AddLayer("ApplePen", "Pen", {}, ctx)); +        UNIT_ASSERT(reg->AddLayer("PineappleApplePen", "ApplePen", {}, ctx)); +        auto layers = reg->ResolveLogicalLayers({{"Pen", "PineappleApplePen"}}, ctx); +        UNIT_ASSERT(layers); +        TVector<TString> exp = {"Pen", "ApplePen", "PineappleApplePen"}; +        UNIT_ASSERT_EQUAL(layers->size(), exp.size()); +        for (size_t i = 0; i < layers->size(); ++i) { +            UNIT_ASSERT((*layers)[i].Name); +            UNIT_ASSERT_STRINGS_EQUAL(exp[i], *((*layers)[i].Name)); +        } +        layers = reg->ResolveLogicalLayers({{"PineappleApplePen"}}, ctx); +        UNIT_ASSERT(layers); +        UNIT_ASSERT_EQUAL(layers->size(), exp.size()); +        for (size_t i = 0; i < layers->size(); ++i) { +            UNIT_ASSERT((*layers)[i].Name); +            UNIT_ASSERT_STRINGS_EQUAL(exp[i], *((*layers)[i].Name)); +        } +        UNIT_ASSERT(reg->AddLayer("foo", {}, "dummy://1", ctx)); + +        layers = reg->ResolveLogicalLayers({{"foo"}}, ctx); +        UNIT_ASSERT(layers); +        auto resolved = reg->ResolveLayers(*layers, "yt", "hahn", ctx); +        UNIT_ASSERT(resolved); +        UNIT_ASSERT_EQUAL(resolved->size(), 1); + +        UNIT_ASSERT(reg->AddLayer("bar", {}, "dummy://2", ctx)); + +        layers = reg->ResolveLogicalLayers({{"bar"}}, ctx); +        UNIT_ASSERT(layers); +        resolved = reg->ResolveLayers(*layers, "yt", "hahn", ctx); +        UNIT_ASSERT(resolved); +        UNIT_ASSERT_EQUAL(resolved->size(), 2); + +        layers = reg->ResolveLogicalLayers({{"bar", "foo"}}, ctx); +        UNIT_ASSERT(layers); +        resolved = reg->ResolveLayers(*layers, "yt", "hahn", ctx); +        UNIT_ASSERT(resolved); +        UNIT_ASSERT_EQUAL(resolved->size(), 1); + +    } + +} | 
