public ConsoleOutput Run()

in logging/api/LoggingTest/LoggingTest.cs [61:297]


        public ConsoleOutput Run(params string[] arguments) =>
            _runner.Run(arguments);

        public void Eventually(Action a) => _retryRobot.Eventually(a);

        public class LoggingTest : BaseTest, IDisposable
        {
            public void Dispose()
            {
                var exceptions = new List<Exception>();
                // Delete all logs created from running the tests.
                foreach (string log in _logsToDelete)
                {
                    try
                    {
                        Run("delete-log", log);
                    }
                    catch (RpcException ex)
                    when (ex.Status.StatusCode == StatusCode.NotFound)
                    { }
                    catch (Exception e)
                    {
                        exceptions.Add(e);
                    }
                }
                // Delete all the log sinks created from running the tests.
                foreach (string sink in _sinksToDelete)
                {
                    try
                    {
                        Run("delete-sink", sink);
                    }
                    catch (RpcException ex)
                    when (ex.Status.StatusCode == StatusCode.NotFound)
                    { }
                    catch (Exception e)
                    {
                        exceptions.Add(e);
                    }
                }
                if (exceptions.Count > 0)
                {
                    throw new AggregateException(exceptions);
                }
            }

            static string RandomName() =>
                GoogleCloudSamples.TestUtil.RandomName();

            [Fact]
            public void TestCreateLogEntry()
            {
                string logId = "logForTestCreateLogEntry" + RandomName();
                string message = "Example log entry.";
                _logsToDelete.Add(logId);
                // Try creating a log entry.
                var created = Run("create-log-entry", logId, message);
                created.AssertSucceeded();
                Eventually(() =>
                {
                    // Retrieve the log entry just added, using the logId as a filter.
                    var results = Run("list-log-entries", logId);
                    // Confirm returned log entry contains expected value.
                    Assert.Contains(message, results.Stdout);
                });
            }

            [Fact(Skip = "https://github.com/GoogleCloudPlatform/dotnet-docs-samples/issues/1066")]
            public void TestListEntries()
            {
                string logId = "logForTestListEntries" + RandomName();
                string message1 = "Example log entry.";
                string message2 = "Another example log entry.";
                string message3 = "Additional example log entry.";
                _logsToDelete.Add(logId);
                // Try creating three log entries.
                Run("create-log-entry", logId, message1).AssertSucceeded();
                Run("create-log-entry", logId, message2).AssertSucceeded();
                Run("create-log-entry", logId, message3).AssertSucceeded();
                Eventually(() =>
                {
                    // Retrieve the log entries just added, using the logId as a filter.
                    var results = Run("list-log-entries", logId);
                    // Confirm returned log entry contains expected value.
                    Assert.Contains(message3, results.Stdout);
                });
            }

            [Fact]
            public void TestWithLogId()
            {
                StackdriverLogWriter.ProjectId = _projectId;
                StackdriverLogWriter.LogId = "TestWithLogId" + RandomName();
                string message1 = "TestWithLogId test example";
                _logsToDelete.Add(StackdriverLogWriter.LogId);
                StackdriverLogWriter.WriteLog("TestWithLogId test example");
                Eventually(() =>
                {
                    // Retrieve the log entries just added, using the logId as a filter.
                    var results = Run("list-log-entries", StackdriverLogWriter.LogId);
                    // Confirm returned log entry contains expected value.
                    Assert.Contains(message1, results.Stdout);
                });
            }

            [Fact(Skip = "delete-log most often reports NotFound, even after 5 " +
                "minutes or so.  The eventual consistency of the API is so " +
                "long that it can't be tested in the limited time " +
                "allotted to a unit test.")]
            public void TestDeleteLog()
            {
                string logId = "logForTestDeleteLog" + RandomName();
                string message = "Example log entry.";
                //Try creating a log entry
                var created = Run("create-log-entry", logId, message);
                created.AssertSucceeded();
                // Try deleting log and assert on success.
                Eventually(() =>
                {
                    Run("delete-log", logId).AssertSucceeded();
                });
            }

            [Fact]
            public void TestCreateSink()
            {
                string sinkId = "sinkForTestCreateSink" + RandomName();
                string logId = "logForTestCreateSink" + RandomName();
                LogSinkName sinkName = new LogSinkName(_projectId, sinkId);
                string message = "Example log entry.";
                _sinksToDelete.Add(sinkId);
                _logsToDelete.Add(logId);
                // Try creating log with log entry.
                var created1 = Run("create-log-entry", logId, message);
                created1.AssertSucceeded();
                // Try creating sink.
                var created2 = Run("create-sink", sinkId, logId);
                created2.AssertSucceeded();
                var sinkClient = ConfigServiceV2Client.Create();
                var results = sinkClient.GetSink(sinkName);
                // Confirm newly created sink is returned.
                Assert.NotNull(results);
            }

            [Fact]
            public void TestListSinks()
            {
                string sinkId = "sinkForTestListSinks" + RandomName();
                string logId = "logForTestListSinks" + RandomName();
                string sinkName = $"projects/{_projectId}/sinks/{sinkId}";
                string message = "Example log entry.";
                _logsToDelete.Add(logId);
                _sinksToDelete.Add(sinkId);
                // Try creating log with log entry.
                var created1 = Run("create-log-entry", logId, message);
                created1.AssertSucceeded();
                // Try creating sink.
                var created2 = Run("create-sink", sinkId, logId);
                created2.AssertSucceeded();
                Eventually(() =>
                {
                    // Try listing sinks.
                    var results = Run("list-sinks");
                    Assert.Equal(0, results.ExitCode);
                });
            }

            [Fact]
            public void TestUpdateSink()
            {
                string sinkId = "sinkForTestUpdateSink" + RandomName();
                string logId = "logForTestUpdateSink" + RandomName();
                string newLogId = "newlogForTestUpdateSink" + RandomName();
                LogSinkName sinkName = new LogSinkName(_projectId, sinkId);
                string message = "Example log entry.";
                _sinksToDelete.Add(sinkId);
                _logsToDelete.Add(logId);
                _logsToDelete.Add(newLogId);
                // Try creating logs with log entries.
                Run("create-log-entry", logId, message).AssertSucceeded();
                Run("create-log-entry", newLogId, message).AssertSucceeded();
                Run("create-sink", sinkId, logId).AssertSucceeded();
                // Try updating sink.
                Run("update-sink", sinkId, newLogId).AssertSucceeded();
                // Get sink to confirm that log has been updated.
                var sinkClient = ConfigServiceV2Client.Create();
                var results = sinkClient.GetSink(sinkName);
                var currentLog = results.Filter;
                Assert.Contains(newLogId, currentLog);
            }

            [Fact]
            public void TestDeleteSink()
            {
                string sinkId = "sinkForTestDeleteSink" + RandomName();
                string logId = "logForTestDeleteSink" + RandomName();
                LogSinkName sinkName = new LogSinkName(_projectId, sinkId);
                string message = "Example log entry.";
                _sinksToDelete.Add(sinkId);
                _logsToDelete.Add(logId);
                // Try creating log with log entry.
                Run("create-log-entry", logId, message).AssertSucceeded();
                // Try creating sink.
                Run("create-sink", sinkId, logId).AssertSucceeded();
                // Try deleting sink.
                Run("delete-sink", sinkId);
                // Get sink to confirm it has been deleted.
                var sinkClient = ConfigServiceV2Client.Create();
                Exception ex = Assert.Throws<Grpc.Core.RpcException>(() =>
                    sinkClient.GetSink(sinkName));
            }

            readonly CommandLineRunner _quickStart = new CommandLineRunner()
            {
                VoidMain = QuickStart.Main,
                Command = "dotnet run"
            };

            [Fact]
            public void TestRunQuickStart()
            {
                string expectedOutput = "Log Entry created.";
                // This logId should match the logId value set in QuickStart\QuickStart.cs
                string logId = "my-log";
                string message = "Hello World!";
                _logsToDelete.Add(logId);
                var output = _quickStart.Run();
                Assert.Equal(expectedOutput, output.Stdout.Trim());
                Eventually(() =>
                {
                    // Retrieve the log entry just added, using the logId as a filter.
                    var results = Run("list-log-entries", logId);
                    // Confirm returned log entry contains expected value.
                    Assert.Contains(message, results.Stdout);
                });
            }
        }