Fehlerdiagnose

From FreeCAD Documentation
Revision as of 22:01, 22 July 2021 by FuzzyBot (talk | contribs) (Updating to match new version of source page)

Erster Test

Bevor du den Schmerz der Fehlerdiagnose durchmachst, benutze das Test Framework, um zu überprüfen, ob die Standardtests ordnungsgemäß funktionieren. Wenn sie nicht vollständig ausgeführt werden, liegt möglicherweise eine defekte Installation vor.

Befehlszeile

Die Fehlerdiagnose von FreeCAD wird durch einige interne Mechanismen unterstützt. Die Kommandozeilenversion von FreeCAD bietet einige Optionen für die Fehlerdiagnoseunterstützung.

Dies sind die derzeit anerkannten Optionen in FreeCAD 0.15:

Grundlegende Optionen:

 -v [ --version ] Druckt Versionszeichenkette
 -h [ --help ] Druckt Hilfsmeldung aus.
 -c [ --console ] Startet im Konsolenmodus
 --response-file arg Kann auch mit'@name' angegeben werden.

Konfiguration:

 -l [ --write-log ]       Schreibt eine Log-Datei nach:
                          $HOME/.FreeCAD/FreeCAD.log
 --log-file arg           Anders als bei --write-log wird hier in eine Datei mit beliebigem Namen geschrieben
 -u [ --user-cfg ] arg    Benutzerkonfigurationsdatei, um Benutzereinstellungen zu laden/speichern
 -s [ --system-cfg ] arg  Systemkonfigurationsdatei, um Systemeinstellungen zu laden/speichern
 -t [ --run-test ] arg    Test-Level
 -M [ --module-path ] arg Zusätzliche Modulpfade
 -P [ --python-path ] arg Zusätzliche Python-Pfade

Erzeugen einer Rückverfolgung

Wenn Du eine FreeCAD Version der Anfangsphase der Entwicklungskurve verwendest, kann sie "abstürzen". Du kannst dabei helfen, diese Probleme zu lösen, indem Du einen "Rückverfolgung" an die Entwickler schickst. Um dies zu tun, musst Du ein "Fehlerdiagnose build" der Software haben. "Fehlerdiagnose build" ist ein Parameter, der zur Kompilierungszeit gesetzt wird, also musst Du entweder FreeCAD selbst kompilieren oder Dir eine vorkompilierte "Fehlerdiagnose" Version besorgen.

Für Linux

Linux Fehlerdiagnose →

Voraussetzungen:

  • Softwarepaket gdb installiert
  • ein Fehlersuch Build von FreeCAD (zur Zeit nur verfügbar unter Bau aus Quelle)
  • ein FreeCAD Modell, das einen Absturz verursacht

Schritte: Gib in deinem Terminalfenster folgendes ein:

Find FreeCAD binary on your system:

$ whereis freecad
freecad: /usr/local/freecad <--- for example

$ cd /usr/local/freecad/bin
$ gdb FreeCAD

GNUdebugger gibt einige Initialisierungsinformationen aus. Die (gdb) zeigt, dass der GNUDebugger im Terminal läuft, das nun eingegeben wird:

(gdb) handle SIG33 noprint nostop
(gdb) run

FreeCAD wird nun gestartet. Führe die Schritte aus, die dazu führen, dass FreeCAD abstürzt oder einfriert, und gib dann in das Terminalfenster ein:

(gdb) bt

Dies führt zu einer langen Auflistung dessen, was das Programm beim Absturz oder Einfrieren genau getan hat. Füge dies deinem Problembericht bei.

(gdb) bt full

Drucke auch die Werte der lokalen Variablen. Dies kann mit einer Zahl kombiniert werden, um die Anzahl der angezeigten Rahmen zu begrenzen.

Für MacOSX

MacOSX Fehlerdiagnose →

Voraussetzungen:

  • Softwarepaket lldb installiert
  • ein Fehlerdiagnose build von FreeCAD
  • ein FreeCAD Modell, dass den Absturz verursacht

Schritte: Gib das Folgende in Dein Terminalfenster ein:

$ cd FreeCAD/bin
$ lldb FreeCAD

LLDB gibt einige Initialisierungsinformationen aus. Die (lldb) zeigt an, dass das Fehlerdiagnoseprogramm im Terminal läuft, jetzt eingegeben:

(lldb) run

FreeCAD wird nun gestartet. Führe die Schritte aus, die dazu führen, dass FreeCAD abstürzt oder einfriert, und gib dann in das Terminalfenster ein:

(lldb) bt

Dies führt zu einer längeren Auflistung dessen, was das Programm genau getan hat, als es abgestürzt ist oder eingefroren ist. Füge dies deinem Problembericht bei.

Von FreeCAD geladene Bibliotheken auflisten

(Anwendbar auf Linux und MacOS)

Manchmal ist es hilfreich zu verstehen, welche Bibliotheken FreeCAD lädt, insbesondere wenn mehrere Bibliotheken mit demselben Namen, aber unterschiedlichen Versionen geladen werden (Versionskollision). Um zu sehen, welche Bibliotheken von FreeCAD geladen werden, wenn es abstürzt, solltest du ein Terminal öffnen und es im Debugger ausführen. In einem zweiten Terminalfenster findest du die Prozess ID von FreeCAD heraus:

ps -A | grep FreeCAD

Verwende die zurückgegebene ID und übergib sie an lsof:

lsof -p process_id

Dadurch wird eine lange Liste der geladenen Ressourcen gedruckt. Wenn z.B. herausgefunden werden soll, ob mehr als eine Coin3d Bibliotheksversion geladen ist, blättere durch die Liste oder suche direkt nach Coin in der Ausgabe:

lsof -p process_id | grep Coin

Python Fehlerdiagnose

Für einen moderneren Ansatz zur Fehlerdiagnose bei Python siehe diese Beiträge:

winpdb

winpdb Fehlerdiagnose →

Hier ist ein Beispiel für die Verwendung von Winpdb in FreeCAD:

Wir benötigen den Python Fehlerdiagnoseprogramm Winpdb. Wenn er nicht installiert ist, lässt sich das auf Ubuntu/Debian wie folgt tun:

sudo apt-get install winpdb

Jetzt werden wir das Fehlerdiagnoseprogramm einrichten.

  1. Starte Winpdb.
  2. Setze das Fehlerdiagnoseprogramm Passwort auf "test": Gehe zum Menü DateiPasswort und setze das Passwort.

Jetzt werden wir ein Python Test-Skript in FreeCAD Schritt-für-Schritt ablaufen lassen.

  1. Starten Sie winpdb und setzen Sie ein Passwort (z.B. Test)
  2. Erzeugen Sie eine Pythondatei mit folgendem Inhalt:
import rpdb2
rpdb2.start_embedded_debugger("test")
import FreeCAD
import Part
import Draft
print "hello"
print "hello"
import Draft
points=[FreeCAD.Vector(-3.0,-1.0,0.0),FreeCAD.Vector(-2.0,0.0,0.0)]
Draft.makeWire(points,closed=False,face=False,support=None)
  1. Starte FreeCAD und lade die obige Datei in FreeCAD.
  2. Drücke F6, um es auszuführen.
  3. Jetzt wird FreeCAD nicht mehr reagieren, weil das Python Fehlerdiagnoseprogramm wartet.
  4. Wechsle zur Windpdb GUI und klicke auf "Anhängen". Nach einigen Sekunden erscheint ein Eintrag "<Eingabe>", in dem du doppelt klicken musst.
  5. Nun erscheint das aktuell ausgeführte Skript in der Winpdb.
  6. Setze einen Bruch in der letzten Zeile und drücke F5.
  7. Drücke nun F7, um in den Python Code von Draft.makeWire zu gelangen.

Visual Studio Code (VS Code)

VS Code Fehlerdiagnose →

Voraussetzungen:

  • Das ptvsd Paket muss installiert werden
pip install ptvsd

pypi Seite

Visual Studio Code Dokumentation für die Fern Fehlerdiagnose

Schritte:

  • Füge folgenden Code am Anfang deines Skripts hinzu
import ptvsd
print("Waiting for debugger attach")
# 5678 is the default attach port in the VS Code debug configurations
ptvsd.enable_attach(address=('localhost', 5678), redirect_output=True)
ptvsd.wait_for_attach()
    "configurations": [
        {
            "name": "Python: Attacher",
            "type": "python",
            "request": "attach",
            "port": 5678,
            "host": "localhost",
            "pathMappings": [
                {
                    "localRoot": "${workspaceFolder}",
                    "remoteRoot": "."
                }
            ]
        },
  • Füge im VS-Code einen Haltepunkt hinzu, wo immer Du willst.
  • Starte das Skript in FreeCAD. FreeCAD Freeze wartet auf den Anhang.
  • In VS Code startest Du die Fehlerdiagnose der verwendeten erstellten Konfiguration. Du solltest Variablen im Fehlerdiagnosebereich sehen.
from sys import path
sys.path.append('/path/to/site-packages')

where the path is to the directory where ptvsd got installed

  • On the left bottom edge of VSCode you can choose the python executable - it's best to make this the version packaged with FreeCAD.

In the Mac package it is /Applications/FreeCAD.App/Contents/Resources/bin/python

You can locate it on your system by typing

import sys
print(sys.executable)

into FreeCAD's python console.

Fehlerdiagnose OpenCasCade

Für Entwickler, die tiefer in den OpenCasCade Kernel einsteigen müssen, hat der Benutzer @abdullah eine Forumsbetrag Orientierung erstellt, in der die Vorgehensweise diskutiert wird.