forked from quickshell/quickshell
		
	io/process: mask the "QProcess destroyed for running process" warn
This commit is contained in:
		
							parent
							
								
									f681e2016f
								
							
						
					
					
						commit
						86591f122d
					
				
					 5 changed files with 88 additions and 3 deletions
				
			
		| 
						 | 
				
			
			@ -27,6 +27,21 @@ Process::Process(QObject* parent): QObject(parent) {
 | 
			
		|||
	);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
Process::~Process() {
 | 
			
		||||
	if (this->process != nullptr && this->process->processId() != 0) {
 | 
			
		||||
		// Deleting after the process finishes hides the process destroyed warning in logs
 | 
			
		||||
		QObject::connect(this->process, &QProcess::finished, [p = this->process] { delete p; });
 | 
			
		||||
 | 
			
		||||
		this->process->setParent(nullptr);
 | 
			
		||||
		this->process->kill();
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void Process::onPostReload() {
 | 
			
		||||
	this->postReload = true;
 | 
			
		||||
	this->startProcessIfReady();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
bool Process::isRunning() const { return this->process != nullptr; }
 | 
			
		||||
 | 
			
		||||
void Process::setRunning(bool running) {
 | 
			
		||||
| 
						 | 
				
			
			@ -165,7 +180,9 @@ void Process::setStdinEnabled(bool enabled) {
 | 
			
		|||
}
 | 
			
		||||
 | 
			
		||||
void Process::startProcessIfReady() {
 | 
			
		||||
	if (this->process != nullptr || !this->targetRunning || this->mCommand.isEmpty()) return;
 | 
			
		||||
	if (this->process != nullptr || !this->postReload || !this->targetRunning
 | 
			
		||||
	    || this->mCommand.isEmpty())
 | 
			
		||||
		return;
 | 
			
		||||
	this->targetRunning = false;
 | 
			
		||||
 | 
			
		||||
	auto& cmd = this->mCommand.first();
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -11,6 +11,7 @@
 | 
			
		|||
#include <qvariant.h>
 | 
			
		||||
 | 
			
		||||
#include "../core/doc.hpp"
 | 
			
		||||
#include "../core/reload.hpp"
 | 
			
		||||
#include "datastream.hpp"
 | 
			
		||||
#include "processcore.hpp"
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -30,7 +31,9 @@
 | 
			
		|||
///   }
 | 
			
		||||
/// }
 | 
			
		||||
/// ```
 | 
			
		||||
class Process: public QObject {
 | 
			
		||||
class Process
 | 
			
		||||
    : public QObject
 | 
			
		||||
    , public PostReloadHook {
 | 
			
		||||
	Q_OBJECT;
 | 
			
		||||
	// clang-format off
 | 
			
		||||
	/// If the process is currently running. Defaults to false.
 | 
			
		||||
| 
						 | 
				
			
			@ -136,6 +139,10 @@ class Process: public QObject {
 | 
			
		|||
 | 
			
		||||
public:
 | 
			
		||||
	explicit Process(QObject* parent = nullptr);
 | 
			
		||||
	~Process() override;
 | 
			
		||||
	Q_DISABLE_COPY_MOVE(Process);
 | 
			
		||||
 | 
			
		||||
	void onPostReload() override;
 | 
			
		||||
 | 
			
		||||
	// MUST be before exec(ctx) or the other will be called with a default constructed obj.
 | 
			
		||||
	QSDOC_HIDE Q_INVOKABLE void exec(QList<QString> command);
 | 
			
		||||
| 
						 | 
				
			
			@ -251,4 +258,5 @@ private:
 | 
			
		|||
	bool targetRunning = false;
 | 
			
		||||
	bool mStdinEnabled = false;
 | 
			
		||||
	bool mClearEnvironment = false;
 | 
			
		||||
	bool postReload = false;
 | 
			
		||||
};
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1,7 +1,8 @@
 | 
			
		|||
function (qs_test name)
 | 
			
		||||
	add_executable(${name} ${ARGN})
 | 
			
		||||
	target_link_libraries(${name} PRIVATE Qt::Quick Qt::Network Qt::Test quickshell-io)
 | 
			
		||||
	target_link_libraries(${name} PRIVATE Qt::Quick Qt::Network Qt::Test quickshell-io quickshell-core quickshell-window quickshell-ui)
 | 
			
		||||
	add_test(NAME ${name} WORKING_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}" COMMAND $<TARGET_FILE:${name}>)
 | 
			
		||||
endfunction()
 | 
			
		||||
 | 
			
		||||
qs_test(datastream datastream.cpp ../datastream.cpp)
 | 
			
		||||
qs_test(process process.cpp ../process.cpp ../datastream.cpp ../processcore.cpp)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										47
									
								
								src/io/test/process.cpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								src/io/test/process.cpp
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,47 @@
 | 
			
		|||
#include "process.hpp"
 | 
			
		||||
 | 
			
		||||
#include <qlist.h>
 | 
			
		||||
#include <qsignalspy.h>
 | 
			
		||||
#include <qtest.h>
 | 
			
		||||
#include <qtestcase.h>
 | 
			
		||||
 | 
			
		||||
#include "../process.hpp"
 | 
			
		||||
 | 
			
		||||
void TestProcess::startAfterReload() {
 | 
			
		||||
	auto process = Process();
 | 
			
		||||
	auto startedSpy = QSignalSpy(&process, &Process::started);
 | 
			
		||||
	auto exitedSpy = QSignalSpy(&process, &Process::exited);
 | 
			
		||||
 | 
			
		||||
	process.setCommand({"true"});
 | 
			
		||||
	process.setRunning(true);
 | 
			
		||||
 | 
			
		||||
	QVERIFY(!process.isRunning());
 | 
			
		||||
	QCOMPARE(startedSpy.count(), 0);
 | 
			
		||||
 | 
			
		||||
	process.onPostReload();
 | 
			
		||||
 | 
			
		||||
	QVERIFY(process.isRunning());
 | 
			
		||||
	QVERIFY(startedSpy.wait(100));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void TestProcess::testExec() {
 | 
			
		||||
	auto process = Process();
 | 
			
		||||
	auto startedSpy = QSignalSpy(&process, &Process::started);
 | 
			
		||||
	auto exitedSpy = QSignalSpy(&process, &Process::exited);
 | 
			
		||||
 | 
			
		||||
	process.onPostReload();
 | 
			
		||||
 | 
			
		||||
	process.setCommand({"sleep", "30"});
 | 
			
		||||
	process.setRunning(true);
 | 
			
		||||
 | 
			
		||||
	QVERIFY(process.isRunning());
 | 
			
		||||
	QVERIFY(startedSpy.wait(100));
 | 
			
		||||
 | 
			
		||||
	process.exec({"true"});
 | 
			
		||||
 | 
			
		||||
	QVERIFY(exitedSpy.wait(100));
 | 
			
		||||
	QVERIFY(startedSpy.wait(100));
 | 
			
		||||
	QVERIFY(process.isRunning());
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
QTEST_MAIN(TestProcess);
 | 
			
		||||
							
								
								
									
										12
									
								
								src/io/test/process.hpp
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/io/test/process.hpp
									
										
									
									
									
										Normal file
									
								
							| 
						 | 
				
			
			@ -0,0 +1,12 @@
 | 
			
		|||
#pragma once
 | 
			
		||||
 | 
			
		||||
#include <qobject.h>
 | 
			
		||||
#include <qtmetamacros.h>
 | 
			
		||||
 | 
			
		||||
class TestProcess: public QObject {
 | 
			
		||||
	Q_OBJECT;
 | 
			
		||||
 | 
			
		||||
private slots:
 | 
			
		||||
	static void startAfterReload();
 | 
			
		||||
	static void testExec();
 | 
			
		||||
};
 | 
			
		||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue