mirror of
https://github.com/OrcaSlicer/OrcaSlicer.git
synced 2026-06-15 08:23:00 +00:00
* Fix null-deref and arranger bugs that gate headless slicing tests export_gcode dereferenced a null result out-param, enum serialization dereferenced a null keys_map, and get_arrange_polys left bed_idx unseeded so the arranger dropped items. All only affect the headless test/CLI path. * Fix the headless test harness and add G-code test helpers Use the real arranger, fix temp-file handling with an RAII guard, and add layers_with_role / max_z for inspecting sliced G-code. * Re-enable the Model construction test * Re-enable SupportMaterial tests and add an enforced-support test * Re-enable and extend PrintObject layer-height and perimeter tests * Re-enable Print skirt, brim, and solid-surface tests * Re-enable and extend PrintGCode tests Un-hide the basic scenario (dead-key fixes, reframes, trimmed trivia) and add initial-layer-height, sequential-order, and null-result export tests. * Re-enable and reframe the skirt/brim tests Detect skirt/brim by G-code role comment instead of a sentinel speed, and resolve the previously-unfinished skirt-enclosure test. * Replace the stale lift()/unlift() test with a z_hop test * Delete the stub and broken Flow tests
48 lines
1.6 KiB
C++
48 lines
1.6 KiB
C++
#ifndef SLIC3R_TEST_UTILS
|
|
#define SLIC3R_TEST_UTILS
|
|
|
|
#include <libslic3r/TriangleMesh.hpp>
|
|
#include <libslic3r/Format/OBJ.hpp>
|
|
|
|
#include <boost/filesystem.hpp>
|
|
|
|
#if defined(WIN32) || defined(_WIN32)
|
|
#define PATH_SEPARATOR R"(\)"
|
|
#else
|
|
#define PATH_SEPARATOR R"(/)"
|
|
#endif
|
|
|
|
inline Slic3r::TriangleMesh load_model(const std::string &obj_filename)
|
|
{
|
|
Slic3r::TriangleMesh mesh;
|
|
auto fpath = TEST_DATA_DIR PATH_SEPARATOR + obj_filename;
|
|
Slic3r::ObjInfo obj_info;
|
|
std::string message;
|
|
Slic3r::load_obj(fpath.c_str(), &mesh, obj_info, message);
|
|
return mesh;
|
|
}
|
|
|
|
// RAII holder for a unique temporary file path, removed when the guard goes out
|
|
// of scope so a failing assertion never leaks it. Uses the system temp dir with
|
|
// a unique name (parallel-safe, cross-platform). The file itself is created by
|
|
// whoever writes to path()/string(); this only reserves the name and cleans up.
|
|
class ScopedTemporaryFile
|
|
{
|
|
public:
|
|
explicit ScopedTemporaryFile(const std::string &extension = ".tmp")
|
|
: m_path(boost::filesystem::temp_directory_path()
|
|
/ boost::filesystem::unique_path("orca-%%%%-%%%%-%%%%" + extension))
|
|
{}
|
|
~ScopedTemporaryFile() { boost::system::error_code ec; boost::filesystem::remove(m_path, ec); }
|
|
ScopedTemporaryFile(const ScopedTemporaryFile &) = delete;
|
|
ScopedTemporaryFile &operator=(const ScopedTemporaryFile &) = delete;
|
|
|
|
const boost::filesystem::path &path() const { return m_path; }
|
|
std::string string() const { return m_path.string(); }
|
|
|
|
private:
|
|
boost::filesystem::path m_path;
|
|
};
|
|
|
|
#endif // SLIC3R_TEST_UTILS
|