Test: Unterschied zwischen den Versionen

Aus Foxwiki
K Dirkwagner verschob die Seite Linuxbefehl: test nach Linuxbefehl:test, ohne dabei eine Weiterleitung anzulegen: Textersetzung - „Linuxbefehl: “ durch „Linuxbefehl:“
K Textersetzung - „== Syntax ==“ durch „== Aufruf ==“
 
(42 dazwischenliegende Versionen von 2 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
Der Befehl ''test'' überprüft Dateien und vergleicht Werte. Vorallem bei Skripten verwendet, um zu testen, ob eine Datei vorhanden ist und ob sie den richtigen Typ hat.
'''test''' - prüft Dateien und vergleicht Werte


==Syntax==
== Beschreibung ==
Vor allem bei Skripten verwendet, um zu testen, ob eine Datei vorhanden ist und ob sie den richtigen Typ hat.


$ test <Datei>
== Aufruf ==
$ test <Wert1> OPTION <Wert2>
<syntaxhighlight lang="bash" highlight="1,2" line>
test <Datei>
test <Wert1> OPTION <Wert2>
</syntaxhighlight>


*Nur ''test'' ohne Parameter oder Ausdrücke liefert immer den Wert FALSCH.
* Nur ''test'' ohne Parameter oder Ausdrücke liefert immer den Wert FALSCH.
*Ein ''test !'' ohne Parameter oder Ausdrücke liefert immer den Wert WAHR.
* Ein ''test !'' ohne Parameter oder Ausdrücke liefert immer den Wert WAHR.
*Um herauszufinden, welcher Wert herauskommt, muss man ''echo $?'' eingeben. 0 ist wahr, 1 ist falsch.
* Um herauszufinden, welcher Wert herauskommt, muss man ''echo $?'' eingeben. 0 ist wahr, 1 ist falsch.
*''Vor und hinter'' dem Operator ein Leerzeichen, sonst wird es als ein Ausdruck wahrgenommen


$ test ; echo Der Errorlevel ist $?
''Vor und hinter'' dem Operator ein Leerzeichen, sonst wird es als ein Ausdruck wahrgenommen
Der Errorlevel ist 1


$ test ! ; echo Der Errorlevel ist $?
<syntaxhighlight lang="bash" highlight="1" line>
Der Errorlevel ist 0
test ; echo Der Errorlevel ist $?
Der Errorlevel ist 1
</syntaxhighlight>


==Optionen==
<syntaxhighlight lang="bash" highlight="1" line>
test ! ; echo Der Errorlevel ist $?
Der Errorlevel ist 0
</syntaxhighlight>


=== Optionen ===
{|class="wikitable"
{|class="wikitable"
|+ Zeichenkette
|+ Zeichenkette
Zeile 89: Zeile 97:
|}
|}


==Quelle==
=== Parameter ===
*Manpage von test
=== Umgebungsvariablen ===
=== Exit-Status ===


[[Category: Linuxbefehle]]
== Anwendung ==
[[Category: Linux]]
$ '''test Ausdruck'''
[[Benutzer:Alexanderrogers|Alexanderrogers]] ([[Benutzer Diskussion:Alexanderrogers|Diskussion]]) 10:07, 17. Sep. 2019 (CEST)
 
test liefert in Abhängigkeit vom Wahrheitswert des Ausdrucks 0 (wahr) oder 1 (falsch) zurück und ist damit ein wichtiger Bestandteil vieler Shellskripten.
 
Es existieren mannigfaltige Klassen von Tests. Doch bevor wir Ihnen eine Auswahl verfügbarer Tests vorstellen, möchten wir auf eine alternative Schreibweise hinweisen, die gern bei bedingter Ausführung eingesetzt wird.
 
Im nachfolgenden Beispiel sind die beiden Zeilen semantisch äquivalent:
 
'''test -z $DISPLAY
[ -z $DISPLAY ]'''
 
Beachten Sie, dass nach der öffnenden eckigen Klammer und vor der schließenden zwingend ein Whitespace stehen muss!
 
Die wohl wichtigsten Tests befassen sich mit Dateien(alle Tests schließen einen Existenztest der Datei mit ein):
 
{|class="wikitable sortable" class="wikitable sortable"
|-
|  | '''-b/-c '''
|  | Test auf Gerätedatei (Block/Character):
|  | '''test -b - /dev/hda; echo $?'''
0
'''test -b /dev/console; echo $?'''
1
|-
|  | '''-d '''
|  | Test auf Verzeichnis:
|  | '''for i in $(ls|head -5); do'''
>(test -d $i && echo "$i ist ein Verzeichnis")
>|| echo "$i ist kein Verzeichnis"
> done
Desktop ist ein Verzeichnis
Linuxfibel ist ein Verzeichnis
Systemprogrammierung ist ein Verzeichnis
allekapitel.htm ist kein Verzeichnis
amanda.rpm ist kein Verzeichnis
|-
|  | '''-e '''
|  | Existenz der Datei
|  |
|-
|  | '''-f '''
|  | Test auf normale Datei:
|  | '''test -f /dev/hda; echo $?'''
1
|-
|  | '''-k '''
|  | Test, ob das »sticky«-Flag auf ein Verzeichnis gesetzt ist:
|  | '''test -k /tmp; echo $?'''
0
|-
|  | '''-p '''
|  | Test auf Pipe:
|  | '''test -p /dev/xconsole; echo $?'''
0
|-
|  | '''-r/-w/-x '''
|  | Test auf Lese-/Schreib-/Ausführungsrecht
|  |
|-
|  | '''-s '''
|  | Test, ob eine Datei nicht leer ist
|  |
|-
|  | '''-u '''
|  | Test, ob das »suid«-Flag auf einer Datei gesetzt ist:
|  | '''test -u /usr/bin/passwd; echo $?'''
0
|-
|}
 
'''Datei_1 -nt Datei_2 bzw. Datei_1 -ot Datei_2 '''
 
Test, ob Datei_1 »neuer« bzw. »älter« ist als die Datei_2
'''Datei_1 -ef Datei_2 '''
 
Test, ob Datei_1 und Datei_2 den selben Inode auf demselben Device besitzen (die eine Datei ist ein harter Link auf die andere):
'''ln bla foo
test bla -ef foo; echo $?'''
0
 
Des Weiteren existieren eine Reihe von Operatoren zum Vergleich von Zeichenketten:
'''-z Zeichenkette '''
Der Test ist wahr, wenn die Zeichenkette die Länge 0 hat
 
'''-n string '''
Der Test ist wahr, wenn die Länge der Zeichenkette >0 ist
 
'''Zeichenkette_1 == Zeichenkette_2 '''
Wahr, wenn die Zeichenketten gleich sind
 
'''Zeichenkette_1 != Zeichenkette_2 '''
Wahr, wenn die Zeichenketten ungleich sind
 
'''Zeichenkette_1 < Zeichenkette_2 '''
Wahr, wenn die Zeichenkette_1 lexikalisch kleiner ist als Zeichenkette_2
 
'''Zeichenkette_1 > Zeichenkette_2 '''
Wahr, wenn die Zeichenkette_1 lexikalisch größer ist als Zeichenkette_2
 
Eine vielseitige Anwendung ist der Vergleich von Argumenten mit den Operatoren -eq (gleich), -ne (ungleich), -gt (größer als), -lt (kleiner als), -ge (größer als oder gleich) und -le (kleiner als oder gleich):
 
# Überprüfung der Anzahl Parameter in einem Shellskript...
'''if [ "$#" -lt "3" ]; then echo "Zu wenige Parameter"; exit 1; fi'''
 
'''Anmerkung '''
Die Prüfung und Beendigung eines Skripts im Fehlerfall lässt sich eleganter über die Parametersubstitution realisieren:
 
# Elegante Überprüfung der Anzahl Parameter in einem Shellskript...
'''var_3 = ${3:?Zu wenige Parameter}'''
 
Mehrere Tests können kombiniert werden:
'''! '''Negation
'''-a '''Logisches UND zweier Tests
'''-o '''Logisches ODER zweier Tests
'''test -b /dev/null -o -c /dev/null
test $? -eq 0 && echo "Gerätedatei"'''
Gerätedatei
 
== Installation ==
 
<noinclude>
 
== Anhang ==
=== Siehe auch ===
 
==== Dokumentation ====
* Manpage von test
 
==== Links ====
===== Projekt =====
===== Weblinks =====
 
[[Kategorie:Linux/Befehl]]
[[Kategorie:Bash/Builtin]]
{{DEFAULTSORT:test}}
{{DISPLAYTITLE:test}}
 
</noinclude>

Aktuelle Version vom 12. November 2024, 19:40 Uhr

test - prüft Dateien und vergleicht Werte

Beschreibung

Vor allem bei Skripten verwendet, um zu testen, ob eine Datei vorhanden ist und ob sie den richtigen Typ hat.

Aufruf

test <Datei>
test <Wert1> OPTION <Wert2>
  • Nur test ohne Parameter oder Ausdrücke liefert immer den Wert FALSCH.
  • Ein test ! ohne Parameter oder Ausdrücke liefert immer den Wert WAHR.
  • Um herauszufinden, welcher Wert herauskommt, muss man echo $? eingeben. 0 ist wahr, 1 ist falsch.

Vor und hinter dem Operator ein Leerzeichen, sonst wird es als ein Ausdruck wahrgenommen

test ; echo Der Errorlevel ist $?
Der Errorlevel ist 1
test ! ; echo Der Errorlevel ist $?
Der Errorlevel ist 0

Optionen

Zeichenkette
Option/Ausdruck Beschreibung Beispiel Errorlevel
ZEICHENKETTE Die Länge der ZEICHENKETTE ist nicht 0 test Beispiel 0
-z ZEICHENKETTE Die Länge der Zeichenkette ist 0 test -z Beispiel 1
ZEICHENKETTE1 = ZEICHENKETTE2 Die Zeichenketten sind identisch test Haha = Haha 0
ZEICHENKETTE1 != ZEICHENKETTE2 Die Zeichenketten sind nicht identisch test Haha != Haha 1
Zahlen
Option/Ausdruck Beschreibung Beispiel Errorlevel
ZAHL1 -eq ZAHL2 ZAHL1 ist gleich ZAHL2 test 5 -eq 5 0
ZAHL1 -ge ZAHL2 ZAHL1 ist größer als oder gleich ZAHL2 test 5 -ge 2 0
ZAHL1 -gt ZAHL2 ZAHL1 ist größer als ZAHL2 test 5 -gt 4 0
ZAHL1 -lt ZAHL2 ZAHL1 ist kleiner als ZAHL2 test 5 -lt 6 0
ZAHL1 -le ZAHL2 ZAHL1 ist kleiner als oder gleich ZAHL2 test 5 -le 7 0
ZAHL1 -ne ZAHL2 ZAHL1 ist nicht gleich ZAHL2 test 5 -ne 5 1

Achtung: test kann nur ganze Zahlen vergleichen.

Dateien
Option/Ausdruck Beschreibung
DATEI1 -ef DATEI2 Die Dateien haben dieselben Geräte- und Inode-Nummern
DATEI1 -nt/-ot DATEI2 Die Datei ist bzgl. seines Änderungsdatums neuer/älter als die andere Datei
-e Die Datei existiert
-f Die Datei existiert und ist eine normale Datei
-d Die Datei existiert und ist ein Verzeichnis
-b Die Datei existiert und ist eine blockorientierte Gerätedatei
-c Die Datei existiert und ist eine charakterorientierte Gerätedatei
-h Die Datei existiert und ist ein Softlink
-p Die Datei existiert und ist eine "Named" Pipe
-S Die Datei existiert und ist ein Socket (Achtung! Großes S verwenden! Siehe kleines s)
-r Die Datei existiert und ist lesbar
-w Die Datei existiert und ist schreibbar
-x Die Datei existiert und ist ausführbar
-s Die Datei existiert und hat eine Dateigröße größer als 0
-u Die Datei existiert und hat das "Set-UID"-Bit gesetzt
-g Die Datei existiert und hat das "Set-GID"-Bit gesetzt
-k Die Datei existiert und hat das "Sticky"-Bit gesetzt

Parameter

Umgebungsvariablen

Exit-Status

Anwendung

$ test Ausdruck

test liefert in Abhängigkeit vom Wahrheitswert des Ausdrucks 0 (wahr) oder 1 (falsch) zurück und ist damit ein wichtiger Bestandteil vieler Shellskripten.

Es existieren mannigfaltige Klassen von Tests. Doch bevor wir Ihnen eine Auswahl verfügbarer Tests vorstellen, möchten wir auf eine alternative Schreibweise hinweisen, die gern bei bedingter Ausführung eingesetzt wird.

Im nachfolgenden Beispiel sind die beiden Zeilen semantisch äquivalent:

test -z $DISPLAY
[ -z $DISPLAY ]

Beachten Sie, dass nach der öffnenden eckigen Klammer und vor der schließenden zwingend ein Whitespace stehen muss!

Die wohl wichtigsten Tests befassen sich mit Dateien(alle Tests schließen einen Existenztest der Datei mit ein):

-b/-c Test auf Gerätedatei (Block/Character): test -b - /dev/hda; echo $?
0
test -b /dev/console; echo $?
1
-d Test auf Verzeichnis: for i in $(ls|head -5); do
>(test -d $i && echo "$i ist ein Verzeichnis")
>|| echo "$i ist kein Verzeichnis"
> done
Desktop ist ein Verzeichnis
Linuxfibel ist ein Verzeichnis
Systemprogrammierung ist ein Verzeichnis
allekapitel.htm ist kein Verzeichnis
amanda.rpm ist kein Verzeichnis
-e Existenz der Datei
-f Test auf normale Datei: test -f /dev/hda; echo $?
1
-k Test, ob das »sticky«-Flag auf ein Verzeichnis gesetzt ist: test -k /tmp; echo $?
0
-p Test auf Pipe: test -p /dev/xconsole; echo $?
0
-r/-w/-x Test auf Lese-/Schreib-/Ausführungsrecht
-s Test, ob eine Datei nicht leer ist
-u Test, ob das »suid«-Flag auf einer Datei gesetzt ist: test -u /usr/bin/passwd; echo $?
0
Datei_1 -nt Datei_2 bzw. Datei_1 -ot Datei_2 

Test, ob Datei_1 »neuer« bzw. »älter« ist als die Datei_2

Datei_1 -ef Datei_2 

Test, ob Datei_1 und Datei_2 den selben Inode auf demselben Device besitzen (die eine Datei ist ein harter Link auf die andere):

ln bla foo
test bla -ef foo; echo $?
0

Des Weiteren existieren eine Reihe von Operatoren zum Vergleich von Zeichenketten:

-z Zeichenkette 

Der Test ist wahr, wenn die Zeichenkette die Länge 0 hat

-n string 

Der Test ist wahr, wenn die Länge der Zeichenkette >0 ist

Zeichenkette_1 == Zeichenkette_2 

Wahr, wenn die Zeichenketten gleich sind

Zeichenkette_1 != Zeichenkette_2 

Wahr, wenn die Zeichenketten ungleich sind

Zeichenkette_1 < Zeichenkette_2 

Wahr, wenn die Zeichenkette_1 lexikalisch kleiner ist als Zeichenkette_2

Zeichenkette_1 > Zeichenkette_2 

Wahr, wenn die Zeichenkette_1 lexikalisch größer ist als Zeichenkette_2

Eine vielseitige Anwendung ist der Vergleich von Argumenten mit den Operatoren -eq (gleich), -ne (ungleich), -gt (größer als), -lt (kleiner als), -ge (größer als oder gleich) und -le (kleiner als oder gleich):

# Überprüfung der Anzahl Parameter in einem Shellskript...
if [ "$#" -lt "3" ]; then echo "Zu wenige Parameter"; exit 1; fi
Anmerkung 
Die Prüfung und Beendigung eines Skripts im Fehlerfall lässt sich eleganter über die Parametersubstitution realisieren: 
# Elegante Überprüfung der Anzahl Parameter in einem Shellskript...
var_3 = ${3:?Zu wenige Parameter}

Mehrere Tests können kombiniert werden:

! Negation 
-a Logisches UND zweier Tests 
-o Logisches ODER zweier Tests 
test -b /dev/null -o -c /dev/null
test $? -eq 0 && echo "Gerätedatei"
Gerätedatei

Installation

Anhang

Siehe auch

Dokumentation

  • Manpage von test

Links

Projekt
Weblinks