[cfe-dev] Random non-reproducible errors in ClangdTests

Mikael Holmén via cfe-dev cfe-dev at lists.llvm.org
Thu Sep 6 06:52:46 PDT 2018


Hi,

Thanks! (I've just joined clangd-dev but haven't been approved yet so I 
didn't see the mails there)

We'll pull in your fix and hopefully the problems will be gone then. 
I'll get back if not.

Thanks,
Mikael

On 09/06/2018 01:59 PM, Ilya Biryukov via cfe-dev wrote:
> +cfe-dev
> 
> On Thu, Sep 6, 2018 at 1:58 PM Ilya Biryukov <ibiryukov at google.com 
> <mailto:ibiryukov at google.com>> wrote:
> 
>     The TSAN logs were produced with non-sanitized standard library, I
>     couldn't reproduce the failures with a sanitized build of libc++.
> 
>     Please check if r341538 fixes the error, there is a good chance it
>     was the root cause.
>     If it doesn't help, please let us know, we'll investigate further.
> 
>     On Thu, Sep 6, 2018 at 1:40 PM Ilya Biryukov <ibiryukov at google.com
>     <mailto:ibiryukov at google.com>> wrote:
> 
>         There was a data race in another test, fixed in r341538.
>         Might be causing these failures, but I couldn't reproduce the
>         original ones, so can't be sure.
> 
>         On Thu, Sep 6, 2018 at 1:01 PM Ilya Biryukov
>         <ibiryukov at google.com <mailto:ibiryukov at google.com>> wrote:
> 
>             Thanks for the logs. Will take a look.
> 
>             On Thu, Sep 6, 2018 at 12:36 PM Kirill Bobyrev
>             <kbobyrev.lists at gmail.com <mailto:kbobyrev.lists at gmail.com>>
>             wrote:
> 
>                 Thanks for the information!
> 
>                 I was able to reproduce many failures in tests using
>                 TSan and MSan. I'm attaching logs for TSan for this
>                 particular test that was originally mentioned
>                 (WorkspaceSymbolsTest.Namespaces): it looks like a data
>                 race in Trace and TUScheduler. The pattern looks to be
>                 the same for all other tests.
> 
>                 +CC Ilya who is knowledgeable about TUScheduler.
> 
>                 I will attach stdout logs of the test failure and whole
>                 TSan output.
> 
>                 Kind regards,
>                 Kirill
> 
>                 thread-sanitizer.logs
>                 <https://drive.google.com/file/d/1D51ldaFyZgJrqugmLlCnIoCe1EsetRC2/view?usp=drive_web>
> 
> 
>                 On Thu, Sep 6, 2018 at 7:54 AM Mikael Holmén
>                 <mikael.holmen at ericsson.com
>                 <mailto:mikael.holmen at ericsson.com>> wrote:
> 
>                     Hi,
> 
>                     On 09/05/2018 10:55 PM, Kirill Bobyrev via cfe-dev
>                     wrote:
>                      > Hi Mikael,
>                      >
>                      > Thanks for pointing that out! Could you share
>                     information about what
>                      > compiler + system you used to build and run tests?
> 
>                     I've seen the failures when compiling with clang
>                     3.6.0 on RHEL 6.9 as
>                     well as gcc 5.4.0 on SLED 11.2.
> 
>                     The valgrind run was made on a binary compiled with
>                     clang 3.6.0 on
>                     Ubuntu 14.04.
> 
>                      > Sometimes, UB is
>                      > relatively easy to reproduce using the same setup.
>                      >
>                      > As Mehmet mentioned, it looks that there might be
>                     uninitialised variable
>                      > given the Valgrind log that you provided.
>                      >
>                      > Could you please attach the whole log so that it
>                     would be easier for us
>                      > to understand the cause of problem(s)?
> 
>                     Sure!
> 
>                     Thanks,
>                     Mikael
> 
>                      >
>                      > +clangd-dev
>                      >
>                      > Kind regards,
>                      > Kirill
>                      >
>                      >> On 5 Sep 2018, at 17:39, Mehmet Erol Sanliturk
>                     via cfe-dev
>                      >> <cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>
>                     <mailto:cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>>> wrote:
>                      >>
>                      >>
>                      >>
>                      >> On Wed, Sep 5, 2018 at 4:19 PM, Mikael Holmén via
>                      >> cfe-dev<cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>
>                     <mailto:cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>>>wrote:
>                      >>
>                      >>     Hi,
>                      >>
>                      >>     For a while now we randomly see failures
>                     when running the
>                      >>     ClangdTests test.
>                      >>
>                      >>     E.g the below but sometimes other failures:
>                      >>
>                      >>     --------
>                      >>     FAIL: Extra Tools Unit Tests ::
>                      >>   
>                       clangd/./ClangdTests/WorkspaceSymbolsTest.Namespaces (16172 of 39758)
>                      >>     ******************** TEST 'Extra Tools Unit
>                     Tests ::
>                      >>   
>                       clangd/./ClangdTests/WorkspaceSymbolsTest.Namespaces' FAILED
>                      >>     ********************
>                      >>     Note: Google Test filter =
>                     WorkspaceSymbolsTest.Namespaces
>                      >>     [==========] Running 1 test from 1 test case.
>                      >>     [----------] Global test environment set-up.
>                      >>     [----------] 1 test from WorkspaceSymbolsTest
>                      >>     [ RUN      ] WorkspaceSymbolsTest.Namespaces
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:151:
>                      >>     Failure
>                      >>     Value of: getSymbols("a")
>                      >>     Expected: has 4 elements and there exists
>                     some permutation of
>                      >>     elements such that:
>                      >>      - element #0 (named "ans1") and (in
>                     container ""), and
>                      >>      - element #1 (named "ai1") and (in
>                     container "ans1"), and
>                      >>      - element #2 (named "ans2") and (in
>                     container "ans1"), and
>                      >>      - element #3 (named "ai2") and (in
>                     container "ans1::ans2")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:153:
>                      >>     Failure
>                      >>     Value of: getSymbols("::")
>                      >>     Expected: has 1 element that (named "ans1")
>                     and (in container "")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:155:
>                      >>     Failure
>                      >>     Value of: getSymbols("::a")
>                      >>     Expected: has 1 element that (named "ans1")
>                     and (in container "")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:158:
>                      >>     Failure
>                      >>     Value of: getSymbols("ans1::")
>                      >>     Expected: has 2 elements and there exists
>                     some permutation of
>                      >>     elements such that:
>                      >>      - element #0 (named "ai1") and (in
>                     container "ans1"), and
>                      >>      - element #1 (named "ans2") and (in
>                     container "ans1")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:160:
>                      >>     Failure
>                      >>     Value of: getSymbols("::ans1")
>                      >>     Expected: has 1 element that (named "ans1")
>                     and (in container "")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:163:
>                      >>     Failure
>                      >>     Value of: getSymbols("::ans1::")
>                      >>     Expected: has 2 elements and there exists
>                     some permutation of
>                      >>     elements such that:
>                      >>      - element #0 (named "ai1") and (in
>                     container "ans1"), and
>                      >>      - element #1 (named "ans2") and (in
>                     container "ans1")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:165:
>                      >>     Failure
>                      >>     Value of: getSymbols("::ans1::ans2")
>                      >>     Expected: has 1 element that (named "ans2")
>                     and (in container "ans1")
>                      >>     Actual: {}
>                      >>   
>                       ../tools/clang/tools/extra/unittests/clangd/FindSymbolsTests.cpp:167:
>                      >>     Failure
>                      >>     Value of: getSymbols("::ans1::ans2::")
>                      >>     Expected: has 1 element that (named "ai2")
>                     and (in container
>                      >>     "ans1::ans2")
>                      >>     Actual: {}
>                      >>     [  FAILED  ] WorkspaceSymbolsTest.Namespaces
>                     (39 ms)
>                      >>     [----------] 1 test from
>                     WorkspaceSymbolsTest (39 ms total)
>                      >>
>                      >>     [----------] Global test environment tear-down
>                      >>     [==========] 1 test from 1 test case ran.
>                     (40 ms total)
>                      >>     [  PASSED  ] 0 tests.
>                      >>     [  FAILED  ] 1 test, listed below:
>                      >>     [  FAILED  ] WorkspaceSymbolsTest.Namespaces
>                      >>
>                      >>      1 FAILED TEST
>                      >>
>                      >>
>                      >>     It can fail and then at once pass again so
>                     something funny is
>                      >>     going on.
>                      >>
>                      >>
>                      >>     I ran valgrind on ClangdTests and then I got
>                     a bunch of
>                      >>     complaints, the first being:
>                      >>
>                      >>
>                      >>     [ RUN      ] ClangdVFSTest.SearchLibDir
>                      >>     Updating file /clangd-test/foo.cpp with
>                     command [/clangd-test]
>                      >>     clang -ffreestanding -xc++ -target
>                     x86_64-linux-unknown -m64
>                      >>     --gcc-toolchain=/randomusr -stdlib=libstdc++
>                     /clangd-test/foo.cpp
>                      >>   
>                       -resource-dir=/data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/../lib/clang/8.0.0
>                      >>     Preamble for file /clangd-test/foo.cpp
>                     cannot be reused.
>                      >>     Attempting to rebuild it.
>                      >>     Built preamble of size 175020 for file
>                     /clangd-test/foo.cpp
>                      >>     ==14605== Thread 2 worker:foo.cpp:
>                      >>     ==14605== Conditional jump or move depends
>                     on uninitialised value(s)
>                      >>     ==14605==    at 0xCDF8A6:
>                      >>   
>                       clang::Sema::SetCtorInitializers(clang::CXXConstructorDecl*, bool,
>                      >>     llvm::ArrayRef<clang::CXXCtorInitializer*>) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0xD01CB9:
>                      >>   
>                       clang::Sema::DefineImplicitDefaultConstructor(clang::SourceLocation,
>                      >>     clang::CXXConstructorDecl*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0xEA3B93:
>                      >>     PerformConstructorInitialization(clang::Sema&,
>                      >>     clang::InitializedEntity const&,
>                     clang::InitializationKind const&,
>                      >>     llvm::MutableArrayRef<clang::Expr*>,
>                      >>     clang::InitializationSequence::Step const&,
>                     bool&, bool, bool,
>                      >>     clang::SourceLocation,
>                     clang::SourceLocation) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0xE9AA3F:
>                      >>   
>                       clang::InitializationSequence::Perform(clang::Sema&,
>                      >>     clang::InitializedEntity const&,
>                     clang::InitializationKind const&,
>                      >>     llvm::MutableArrayRef<clang::Expr*>,
>                     clang::QualType*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0xBFA3C4:
>                      >>   
>                       clang::Sema::ActOnUninitializedDecl(clang::Decl*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13C5EFF:
>                      >>   
>                       clang::Parser::ParseDeclarationAfterDeclaratorAndAttributes(clang::Declarator&,
>                      >>     clang::Parser::ParsedTemplateInfo const&,
>                      >>     clang::Parser::ForRangeInit*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13C40B7:
>                      >>   
>                       clang::Parser::ParseDeclGroup(clang::ParsingDeclSpec&,
>                      >>     clang::DeclaratorContext,
>                     clang::SourceLocation*,
>                      >>     clang::Parser::ForRangeInit*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13AAF5B:
>                      >>   
>                       clang::Parser::ParseDeclOrFunctionDefInternal(clang::Parser::ParsedAttributesWithRange&,
>                      >>     clang::ParsingDeclSpec&,
>                     clang::AccessSpecifier) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13AAA1D:
>                      >>   
>                       clang::Parser::ParseDeclarationOrFunctionDefinition(clang::Parser::ParsedAttributesWithRange&,
>                      >>     clang::ParsingDeclSpec*,
>                     clang::AccessSpecifier) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13A9861:
>                      >>   
>                       clang::Parser::ParseExternalDeclaration(clang::Parser::ParsedAttributesWithRange&,
>                      >>     clang::ParsingDeclSpec*) (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13A8629:
>                      >>   
>                       clang::Parser::ParseTopLevelDecl(clang::OpaquePtr<clang::DeclGroupRef>&)
>                      >>     (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==    by 0x13A840F:
>                      >>   
>                       clang::Parser::ParseFirstTopLevelDecl(clang::OpaquePtr<clang::DeclGroupRef>&)
>                      >>     (in
>                      >>   
>                       /data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/ClangdTests)
>                      >>     ==14605==
>                      >>     Updating file /clangd-test/foo.cpp with
>                     command [/clangd-test]
>                      >>     clang -ffreestanding -xc++ -target
>                     x86_64-linux-unknown -m64
>                      >>     --gcc-toolchain=/randomusr -stdlib=libstdc++
>                     /clangd-test/foo.cpp
>                      >>   
>                       -resource-dir=/data/repo/llvm-patch/build-all/tools/clang/tools/extra/unittests/clangd/../lib/clang/8.0.0
>                      >>     Reusing preamble for file /clangd-test/foo.cpp
>                      >>     [       OK ] ClangdVFSTest.SearchLibDir (952 ms)
>                      >>
>                      >>
>                      >>
>                      >>     It's not obvious to me what the problem
>                     really is. Does anyone
>                      >>     here have a clue?
>                      >>
>                      >>     Regards,
>                      >>     Mikael
>                      >>     _______________________________________________
>                      >>
>                      >>
>                      >>
>                      >>
>                      >>
>                      >> One reason of non-reproducible errors in a
>                     program is mainly
>                      >> "uninitialized variables" .
>                      >> These variables uses whatever remains in the
>                     memory from previous
>                      >> allocations and used by the new program .
>                      >> Therefore when these values are used , program
>                     behavior is unexpected .
>                      >>
>                      >>
>                      >> Another may be "array index showing outside of
>                     an array" . Especially
>                      >> in loops , if loop passes array boundaries
>                     toward up or down  .
>                      >> Or , when a value is directly used to index an
>                     array , but it is out
>                      >> of bounds .
>                      >>
>                      >>
>                      >> The above reasons are not , "all" , but "some" .
>                      >>
>                      >>
>                      >>
>                      >>
>                      >> Mehmet Erol Sanliturk
>                      >>
>                      >>
>                      >>
>                      >>
>                      >>
>                      >> _______________________________________________
>                      >> cfe-dev mailing list
>                      >> cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>
>                     <mailto:cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>>
>                      >>
>                     http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev
>                      >
>                      >
>                      >
>                      > _______________________________________________
>                      > cfe-dev mailing list
>                      > cfe-dev at lists.llvm.org
>                     <mailto:cfe-dev at lists.llvm.org>
>                      >
>                     http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev
>                      >
> 
> 
> 
>             -- 
>             Regards,
>             Ilya Biryukov
> 
> 
> 
>         -- 
>         Regards,
>         Ilya Biryukov
> 
> 
> 
>     -- 
>     Regards,
>     Ilya Biryukov
> 
> 
> 
> -- 
> Regards,
> Ilya Biryukov
> 
> 
> _______________________________________________
> cfe-dev mailing list
> cfe-dev at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-dev
> 




More information about the cfe-dev mailing list