xref: /llvm-project/llvm/unittests/ADT/EditDistanceTest.cpp (revision 38818b60c58c76ba89b990978cdfd2d7b6799260)
1638b0fb4SNathan James //===- llvm/unittest/Support/EditDistanceTest.cpp - Edit distance tests ---===//
2638b0fb4SNathan James //
3638b0fb4SNathan James // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4638b0fb4SNathan James // See https://llvm.org/LICENSE.txt for license information.
5638b0fb4SNathan James // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6638b0fb4SNathan James //
7638b0fb4SNathan James //===----------------------------------------------------------------------===//
8638b0fb4SNathan James 
9638b0fb4SNathan James #include "llvm/ADT/StringRef.h"
10638b0fb4SNathan James #include "llvm/ADT/edit_distance.h"
11638b0fb4SNathan James #include "gtest/gtest.h"
12638b0fb4SNathan James #include <cstdlib>
13638b0fb4SNathan James 
14638b0fb4SNathan James using namespace llvm;
15638b0fb4SNathan James 
16638b0fb4SNathan James namespace {
17638b0fb4SNathan James 
18638b0fb4SNathan James struct Result {
19638b0fb4SNathan James   unsigned NumMaps;
20638b0fb4SNathan James   unsigned EditDist;
21638b0fb4SNathan James };
22638b0fb4SNathan James } // namespace
23638b0fb4SNathan James 
editDistanceAndMaps(StringRef A,StringRef B,unsigned MaxEditDistance=0)24638b0fb4SNathan James static Result editDistanceAndMaps(StringRef A, StringRef B,
25638b0fb4SNathan James                                   unsigned MaxEditDistance = 0) {
26638b0fb4SNathan James   unsigned NumMaps = 0;
27638b0fb4SNathan James   auto TrackMaps = [&](const char X) {
28638b0fb4SNathan James     ++NumMaps;
29638b0fb4SNathan James     return X;
30638b0fb4SNathan James   };
31638b0fb4SNathan James   unsigned EditDist = llvm::ComputeMappedEditDistance(
32*38818b60Sserge-sans-paille       ArrayRef(A.data(), A.size()), ArrayRef(B.data(), B.size()), TrackMaps,
33*38818b60Sserge-sans-paille       true, MaxEditDistance);
34638b0fb4SNathan James   return {NumMaps, EditDist};
35638b0fb4SNathan James }
36638b0fb4SNathan James 
TEST(EditDistance,VerifyShortCircuit)37638b0fb4SNathan James TEST(EditDistance, VerifyShortCircuit) {
38638b0fb4SNathan James   StringRef Hello = "Hello";
39638b0fb4SNathan James   StringRef HelloWorld = "HelloWorld";
40638b0fb4SNathan James   Result R = editDistanceAndMaps(Hello, HelloWorld, 5);
41638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 5U);
42638b0fb4SNathan James   EXPECT_GT(R.NumMaps, 0U);
43638b0fb4SNathan James 
44638b0fb4SNathan James   R = editDistanceAndMaps(Hello, HelloWorld);
45638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 5U);
46638b0fb4SNathan James   EXPECT_GT(R.NumMaps, 0U);
47638b0fb4SNathan James 
48638b0fb4SNathan James   R = editDistanceAndMaps(Hello, HelloWorld, 4);
49638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 5U);
50638b0fb4SNathan James   EXPECT_EQ(R.NumMaps, 0U);
51638b0fb4SNathan James 
52638b0fb4SNathan James   R = editDistanceAndMaps(HelloWorld, Hello, 4);
53638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 5U);
54638b0fb4SNathan James   EXPECT_EQ(R.NumMaps, 0U);
55638b0fb4SNathan James 
56638b0fb4SNathan James   R = editDistanceAndMaps(Hello, HelloWorld, 1);
57638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 2U);
58638b0fb4SNathan James   EXPECT_EQ(R.NumMaps, 0U);
59638b0fb4SNathan James 
60638b0fb4SNathan James   R = editDistanceAndMaps(HelloWorld, Hello, 1);
61638b0fb4SNathan James   EXPECT_EQ(R.EditDist, 2U);
62638b0fb4SNathan James   EXPECT_EQ(R.NumMaps, 0U);
63638b0fb4SNathan James }
64