Edit

kc3-lang/angle/src/common/system_utils.h

Branch :

  • Show log

    Commit

  • Author : Jamie Madill
    Date : 2019-05-03 12:52:22
    Hash : 58957f3d
    Message : Add option to run each test config in a separate process. This CL adds a command line option to angle_end2end_tests that will iterate over all test configs. For each config it'll fork a new child process that will run only a single config. This will allow us to isolate each config to a specific child process. Hopefully this will reduce test flakiness due to driver issues with multiple configs. The command line option is "--separate-process-per-config". Note that there are about 25 configs right now. Bug: angleproject:3393 Change-Id: Ia117b371bbe159c1b0d28d82befffeb0f40467a9 Reviewed-on: https://chromium-review.googlesource.com/c/angle/angle/+/1591428 Commit-Queue: Jamie Madill <jmadill@chromium.org> Reviewed-by: Yuly Novikov <ynovikov@chromium.org>

  • src/common/system_utils.h
  • //
    // Copyright (c) 2014 The ANGLE Project Authors. All rights reserved.
    // Use of this source code is governed by a BSD-style license that can be
    // found in the LICENSE file.
    //
    
    // system_utils.h: declaration of OS-specific utility functions
    
    #ifndef COMMON_SYSTEM_UTILS_H_
    #define COMMON_SYSTEM_UTILS_H_
    
    #include "common/Optional.h"
    #include "common/angleutils.h"
    
    namespace angle
    {
    std::string GetExecutablePath();
    std::string GetExecutableDirectory();
    const char *GetSharedLibraryExtension();
    Optional<std::string> GetCWD();
    bool SetCWD(const char *dirName);
    bool SetEnvironmentVar(const char *variableName, const char *value);
    bool UnsetEnvironmentVar(const char *variableName);
    std::string GetEnvironmentVar(const char *variableName);
    const char *GetPathSeparator();
    bool PrependPathToEnvironmentVar(const char *variableName, const char *path);
    
    // Run an application and get the output.  Gets a nullptr-terminated set of args to execute the
    // application with, and returns the stdout and stderr outputs as well as the exit code.
    //
    // Pass nullptr for stdoutOut/stderrOut if you don't need to capture. exitCodeOut is required.
    //
    // Returns false if it fails to actually execute the application.
    bool RunApp(const std::vector<const char *> &args,
                std::string *stdoutOut,
                std::string *stderrOut,
                int *exitCodeOut);
    
    class Library : angle::NonCopyable
    {
      public:
        virtual ~Library() {}
        virtual void *getSymbol(const char *symbolName) = 0;
        virtual void *getNative() const                 = 0;
    
        template <typename FuncT>
        void getAs(const char *symbolName, FuncT *funcOut)
        {
            *funcOut = reinterpret_cast<FuncT>(getSymbol(symbolName));
        }
    };
    
    Library *OpenSharedLibrary(const char *libraryName);
    }  // namespace angle
    
    #endif  // COMMON_SYSTEM_UTILS_H_