public void ExitOnChange() { using (var scenario = new NoDepsAppScenario()) { // Wait for the process to start using (var wait = new WaitForFileToChange(scenario.StartedFile)) { scenario.RunDotNetWatch($"--exit-on-change -- {scenario.StatusFile} --no-exit"); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"File not created: {scenario.StartedFile}"); } // Change a file var fileToChange = Path.Combine(scenario.TestAppFolder, "Program.cs"); var programCs = File.ReadAllText(fileToChange); File.WriteAllText(fileToChange, programCs); Waiters.WaitForProcessToStop( scenario.WatcherProcess.Id, _defaultTimeout, expectedToStop: true, errorMessage: "The watcher did not stop"); // Check that the first child process is no longer running var ids = File.ReadAllLines(scenario.StatusFile); var firstProcessId = int.Parse(ids[0]); Waiters.WaitForProcessToStop( firstProcessId, TimeSpan.FromSeconds(1), expectedToStop: true, errorMessage: $"PID: {firstProcessId} is still alive"); } }
public void RestartProcessThatTerminatesAfterFileChange() { using (var scenario = new NoDepsAppScenario()) { // Wait for the process to start using (var wait = new WaitForFileToChange(scenario.StartedFile)) { scenario.RunDotNetWatch($"run {scenario.StatusFile}"); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"File not created: {scenario.StartedFile}"); } // Then wait for the app to exit Waiters.WaitForFileToBeReadable(scenario.StartedFile, _defaultTimeout); var ids = File.ReadAllLines(scenario.StatusFile); var procId = int.Parse(ids[0]); Waiters.WaitForProcessToStop( procId, _defaultTimeout, expectedToStop: true, errorMessage: "Test app did not exit"); // Then wait for it to restart when we change a file using (var wait = new WaitForFileToChange(scenario.StartedFile)) { // On Unix the file write time is in 1s increments; // if we don't wait, there's a chance that the polling // watcher will not detect the change Thread.Sleep(1000); var fileToChange = Path.Combine(scenario.TestAppFolder, "Program.cs"); var programCs = File.ReadAllText(fileToChange); File.WriteAllText(fileToChange, programCs); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"Process did not restart because {scenario.StartedFile} was not changed"); } } }
public void RestartProcessThatTerminatesAfterFileChange() { using (var scenario = new NoDepsAppScenario()) { // Wait for the process to start using (var wait = new WaitForFileToChange(scenario.StartedFile)) { scenario.RunDotNetWatch($"run {scenario.StatusFile}"); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"File not created: {scenario.StartedFile}"); } // Then wait for the app to exit Waiters.WaitForFileToBeReadable(scenario.StartedFile, _defaultTimeout); var ids = File.ReadAllLines(scenario.StatusFile); var procId = int.Parse(ids[0]); Waiters.WaitForProcessToStop( procId, _defaultTimeout, expectedToStop: true, errorMessage: "Test app did not exit"); // Then wait for it to restart when we change a file using (var wait = new WaitForFileToChange(scenario.StartedFile)) { // On Unix the file write time is in 1s increments; // if we don't wait, there's a chance that the polling // watcher will not detect the change Thread.Sleep(1000); var fileToChange = Path.Combine(scenario.TestAppFolder, "Program.cs"); var programCs = File.ReadAllText(fileToChange); File.WriteAllText(fileToChange, programCs); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"Process did not restart because {scenario.StartedFile} was not changed"); } } }
public void RestartProcessOnFileChange() { using (var scenario = new NoDepsAppScenario()) { // Wait for the process to start using (var wait = new WaitForFileToChange(scenario.StartedFile)) { scenario.RunDotNetWatch($"run {scenario.StatusFile} --no-exit"); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"File not created: {scenario.StartedFile}"); } // Then wait for it to restart when we change a file using (var wait = new WaitForFileToChange(scenario.StartedFile)) { var fileToChange = Path.Combine(scenario.TestAppFolder, "Program.cs"); var programCs = File.ReadAllText(fileToChange); File.WriteAllText(fileToChange, programCs); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"Process did not restart because {scenario.StartedFile} was not changed"); } // Check that the first child process is no longer running Waiters.WaitForFileToBeReadable(scenario.StatusFile, _defaultTimeout); var ids = File.ReadAllLines(scenario.StatusFile); var firstProcessId = int.Parse(ids[0]); Waiters.WaitForProcessToStop( firstProcessId, TimeSpan.FromSeconds(1), expectedToStop: true, errorMessage: $"PID: {firstProcessId} is still alive"); } }
public void RestartProcessOnFileChange() { using (var scenario = new NoDepsAppScenario()) { // Wait for the process to start using (var wait = new WaitForFileToChange(scenario.StartedFile)) { scenario.RunDotNetWatch($"run {scenario.StatusFile} --no-exit"); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"File not created: {scenario.StartedFile}"); } // Then wait for it to restart when we change a file using (var wait = new WaitForFileToChange(scenario.StartedFile)) { var fileToChange = Path.Combine(scenario.TestAppFolder, "Program.cs"); var programCs = File.ReadAllText(fileToChange); File.WriteAllText(fileToChange, programCs); wait.Wait(_defaultTimeout, expectedToChange: true, errorMessage: $"Process did not restart because {scenario.StartedFile} was not changed"); } // Check that the first child process is no longer running Waiters.WaitForFileToBeReadable(scenario.StatusFile, _defaultTimeout); var ids = File.ReadAllLines(scenario.StatusFile); var firstProcessId = int.Parse(ids[0]); Waiters.WaitForProcessToStop( firstProcessId, TimeSpan.FromSeconds(1), expectedToStop: true, errorMessage: $"PID: {firstProcessId} is still alive"); } }