Concat: Unterschied zwischen den Versionen

Aus JACK Wiki
Zur Navigation springen Zur Suche springen
KKeine Bearbeitungszusammenfassung
 
(11 dazwischenliegende Versionen von 4 Benutzern werden nicht angezeigt)
Zeile 1: Zeile 1:
===Zugehörige Evaluatoren===
*'''MathEvaluator'''
=== Beschreibung ===
=== Beschreibung ===
Die Funktion ''concat'' fügt einer Zeichenkette eine zweite Zeichenkette unmittelbar an, so dass eine einzige Zeichenkette entsteht. Die Funktion erwartet zwei Strings und gibt einen String zurück.
Die Funktion ''concat'' fügt Zeichenketten unmittelbar aneinander, so dass eine einzige Zeichenkette entsteht. Die Funktion erwartet zwei oder mehr Zeichenketten und gibt eine Zeichenkette zurück.


=== Syntax ===
=== Syntax ===
  concat(String zeichenkette1, String zeichenkette2)
  concat([[Zeichenkette]] zeichenkette1, [[Zeichenkette]] zeichenkette2)


=== Parameter ===
=== Parameter ===
Zeile 15: Zeile 18:
==== Standardfälle ====
==== Standardfälle ====
  concat('hallo','welt')  --> returns 'hallowelt'
  concat('hallo','welt')  --> returns 'hallowelt'
concat('hallo','welt','!')  --> returns 'hallowelt!'


==== Benutzung von Variablen ====
==== Benutzung mit Variablen ====
concat('[pos=1]','ende')
concat('anfang','[var=a]')
concat('[var=b]','[pos=2]')
 
====JUnit Tests====
<span class="mw-customtoggle-myDivision">[Anzeigen]</span>
<syntaxhighlight lang="java" class="mw-collapsible mw-collapsed" id="mw-customcollapsible-myDivision">
@BeforeClass
public static void beforeTest() {
concatFillInVariableMap.put(1, OMConverter.toObject("<OMOBJ><OMSTR>Hallo</OMSTR></OMOBJ>"));
 
concatExerciseVariableMap.put("a", OMConverter.toObject("<OMOBJ><OMSTR>Hallo</OMSTR></OMOBJ>"));
}
 
@Test
public void testConcat1() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR("HalloHallo")),
Evaluator.evaluate("concat('Hallo','Hallo')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test
public void testConcat2() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR("Hallo  Hallo")),
Evaluator.evaluate("concat('Hallo ',' Hallo')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test
public void testConcat3() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR(" ")),
Evaluator.evaluate("concat(' ','')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test
public void testConcat4() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR(" ")),
Evaluator.evaluate("concat('',' ')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test
public void testConcatWithInput() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR("HalloHallo")),
Evaluator.evaluate("concat('[pos=1]','[pos=1]')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test
public void testConcatWithVariables() {
assertEquals(OMCreator.createOMOBJ(OMCreator.createOMSTR("HalloHallo")),
Evaluator.evaluate("concat('[var=a]','[var=a]')", concatExerciseVariableMap, concatFillInVariableMap));
}
 
@Test(expected = ParserException.class)
public void testConcatWithWrongInputCharacter() {
Evaluator.evaluate("concat(ab,'abcd')", concatExerciseVariableMap, concatFillInVariableMap);
fail();
}
 
@Test(expected = FunctionInvalidNumberOfArgumentsException.class)
public void testConcatWithOneArgument() {
Evaluator.evaluate("concat('abcd')", concatExerciseVariableMap, concatFillInVariableMap);
fail();
}
 
@Test
public void testConcatWithOneRationalAndOneTextArgument() {
Evaluator.evaluate("concat(12, 'abcd')", concatExerciseVariableMap, concatFillInVariableMap);
}


@Test
concat('anfang', [var=a])
public void testConcatWithTwoRationalArguments() {
concat([var=b], 'welt')
Evaluator.evaluate("concat(12, 14)", concatExerciseVariableMap, concatFillInVariableMap);
}


@Test
==== Benutzung mit studentischen Eingaben ====
public void testConcatWithThreeArguments() {
Evaluator.evaluate("concat('abcd', 'efg', 'hij')", concatExerciseVariableMap, concatFillInVariableMap);
}


@Test(expected = UndefinedExerciseVariableException.class)
'''Jack2:'''
public void testConcatWithMissingExcerciseVariable() {
concat([pos=1],'ende')
Evaluator.evaluate("concat('[var=j]','abcd')", concatExerciseVariableMap, concatFillInVariableMap);
concat([var=b],[pos=2])
fail();
}


@Test(expected = UndefinedFillInVariableException.class)
'''Jack3:'''
public void testConcatWithMissingInput() {
concat([input=field1],'ende')
Evaluator.evaluate("concat([pos=42],'abcd')", concatExerciseVariableMap, concatFillInVariableMap);
concat([var=b],[input=field2])
fail();
}
</syntaxhighlight>


=== Hinweise ===
=== Hinweise ===
* Wenn Variablen genutzt werden muss darauf geachtet werden, dass diese die Voraussetzung erfüllen.
* Wenn die Eingabe der Studierenden genutzt wird muss auch hier darauf geachtet werden, dass die Voraussetzungen erfüllt sind und ob diese an der Stelle genutzt werden können.


[[Kategorie:Evaluatorfunktion]]
[[Kategorie:Math-Evaluatorfunktion]][[Kategorie:Zeichenkettenfunktionen]][[Kategorie:JACK2]][[Kategorie:JACK3]]

Aktuelle Version vom 15. April 2024, 13:33 Uhr

Zugehörige Evaluatoren

  • MathEvaluator

Beschreibung

Die Funktion concat fügt Zeichenketten unmittelbar aneinander, so dass eine einzige Zeichenkette entsteht. Die Funktion erwartet zwei oder mehr Zeichenketten und gibt eine Zeichenkette zurück.

Syntax

concat(Zeichenkette zeichenkette1, Zeichenkette zeichenkette2)

Parameter

  • zeichenkette1 - erste Zeichenkette
  • zeichenkette2 - zweite Zeichenkette, die der ersten angehängt werden soll

Return Value

  • Gibt einen String zurück

Beispiele

Standardfälle

concat('hallo','welt')   --> returns 'hallowelt'

concat('hallo','welt','!')   --> returns 'hallowelt!'

Benutzung mit Variablen

concat('anfang', [var=a])
concat([var=b], 'welt')

Benutzung mit studentischen Eingaben

Jack2:
concat([pos=1],'ende')
concat([var=b],[pos=2])
Jack3:
concat([input=field1],'ende')
concat([var=b],[input=field2])

Hinweise

  • Wenn Variablen genutzt werden muss darauf geachtet werden, dass diese die Voraussetzung erfüllen.
  • Wenn die Eingabe der Studierenden genutzt wird muss auch hier darauf geachtet werden, dass die Voraussetzungen erfüllt sind und ob diese an der Stelle genutzt werden können.