
================================================================================
Test Case #1
================================================================================

================================================================================
Test Case ID: 1
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        numbers.Add(6);
        numbers.Insert(2, 7);


SUFFIX CODE:
----------------------------------------
        Debug.Assert(numbers.Count == 5, "List should contain 5 elements");
        Debug.Assert(numbers[2] == 3, "Third element should be 3");
        numbers.RemoveAt(2);
        Debug.Assert(numbers.Count == 4, "List should contain 4 elements after removal");
        Debug.Assert(!numbers.Contains(3), "List should not contain 3 after removal");
    }
}


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to recognize and continue the pattern of manipulating a List in C#. The prefix initializes a List and the suffix includes assertions to ensure the correct state of the List after manipulations. The golden completion involves adding and inserting elements into the List, which is a common pattern in List manipulations.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #2
================================================================================

================================================================================
Test Case ID: 2
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        numbers.Add(6);
        Debug.Assert(numbers.Count == 6, "Count should be 6 after addition");
        Debug.Assert(numbers.Contains(6), "List should contain 6 after addition");


SUFFIX CODE:
----------------------------------------
        numbers.Remove(3);
        Debug.Assert(numbers.Count == 4, "Count should be 4 after removal");
        Debug.Assert(!numbers.Contains(3), "List should not contain 3 after removal");
    }
}


JUSTIFICATION:
----------------------------------------
This test case examines the model's ability to recognize and complete a common pattern in data structure manipulation, specifically with Lists in C#. The code checks the ability to add an element to the List and verifies the addition with assertions. The minimal context is provided through the initial List setup, and the expected behavior is clearly defined through the assertions.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #3
================================================================================

================================================================================
Test Case ID: 3
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        numbers.Remove(3);


SUFFIX CODE:
----------------------------------------
        int sum = 0;
        foreach (var number in numbers)
        {
            sum += number;
        }
        Debug.Assert(sum == 12, "Sum should be 12");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a pattern involving List data structure manipulation. The removal of an element from the list is a common operation, and the subsequent calculation of the sum is used to verify correctness. The assertions ensure that the model understands the impact of the removal operation on the list contents.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #4
================================================================================

================================================================================
Test Case ID: 4
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Collections.Generic;

public class Program
{
    public static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
        List<int> squaredNumbers = new List<int>();


GOLDEN COMPLETION:
----------------------------------------
        foreach (int number in numbers)
        {
            squaredNumbers.Add(number * number);
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(squaredNumbers.Count == 5, "The squaredNumbers list should have 5 elements.");
        Debug.Assert(squaredNumbers[0] == 1, "The first element should be 1.");
        Debug.Assert(squaredNumbers[1] == 4, "The second element should be 4.");
        Debug.Assert(squaredNumbers[2] == 9, "The third element should be 9.");
        Debug.Assert(squaredNumbers[3] == 16, "The fourth element should be 16.");
        Debug.Assert(squaredNumbers[4] == 25, "The fifth element should be 25.");
    }
}


JUSTIFICATION:
----------------------------------------
This test case is a good example of low-context pattern recognition because it requires the model to understand the common pattern of iterating over a list and performing a transformation on each element (in this case, squaring the numbers). The prefix sets up the context with the list of numbers and an empty list for the squared numbers, while the golden completion provides the correct loop to fill the squaredNumbers list. The suffix contains assertions to verify the correctness of the transformation, ensuring that the model's completion is accurate.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #5
================================================================================

================================================================================
Test Case ID: 5
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        var numbers = new int[] {1, 2, 3, 4, 5};
        int sum = 0;


GOLDEN COMPLETION:
----------------------------------------
        foreach (var number in numbers)
        {
            sum += number;
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(sum == 15, "Sum should be 15");
        Console.WriteLine("Sum is correct: " + sum);
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a common pattern of iterating over an array to calculate the sum of its elements. The pattern is clear and identifiable with minimal context, and the assertions ensure the correct functionality of the loop.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #6
================================================================================

================================================================================
Test Case ID: 6
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4 };


GOLDEN COMPLETION:
----------------------------------------
        numbers.Add(5);


SUFFIX CODE:
----------------------------------------
        Debug.Assert(numbers.Count == 5, "Count should be 5");
        Debug.Assert(numbers[4] == 5, "Last element should be 5");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and continue a list manipulation pattern with minimal context. The prefix sets up a list and the suffix contains assertions that verify the list's state after the completion, ensuring the model correctly adds an element to the list.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #7
================================================================================

================================================================================
Test Case ID: 7
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        try
        {


GOLDEN COMPLETION:
----------------------------------------
            string input = null;
            if (input == null)
            {
                throw new ArgumentNullException(nameof(input));
            }


SUFFIX CODE:
----------------------------------------
        }
        catch (ArgumentNullException ex)
        {
            Debug.Assert(ex.ParamName == "input", "Expected ArgumentNullException for input parameter");
        }
    }
}


JUSTIFICATION:
----------------------------------------
This test case checks the LLM's ability to recognize and complete an error handling pattern involving argument validation and exception throwing. The prefix sets up a try block, and the golden completion involves throwing an ArgumentNullException when a null input is detected. The suffix handles the exception and includes an assertion to verify the correct exception was thrown, ensuring the pattern is recognized and properly implemented.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #8
================================================================================

================================================================================
Test Case ID: 8
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        int[] numbers = { 1, 2, 3, 4, 5 };
        int result = 0;
        foreach (int number in numbers)
        {


GOLDEN COMPLETION:
----------------------------------------
            result += number;


SUFFIX CODE:
----------------------------------------
        }
        Debug.Assert(result == 15, "Sum should be 15");
        Console.WriteLine("Sum: " + result);
    }
}


JUSTIFICATION:
----------------------------------------
This test case evaluates the model's ability to recognize and complete a simple iteration pattern over an array, summing its elements. The context is minimal, but the pattern is clear and common, making it an effective benchmark for low-context pattern recognition.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #9
================================================================================

================================================================================
Test Case ID: 9
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
        List<int> evenNumbers = new List<int>();


GOLDEN COMPLETION:
----------------------------------------
        foreach (var number in numbers)
        {
            if (number % 2 == 0)
            {
                evenNumbers.Add(number);
            }
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(evenNumbers.Count == 2, "There should be 2 even numbers.");
        Debug.Assert(evenNumbers.Contains(2), "List should contain 2.");
        Debug.Assert(evenNumbers.Contains(4), "List should contain 4.");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete an iterator and collection pattern. The context is minimal but provides enough information for a common pattern of filtering a collection based on a condition. The assertions verify that the correct even numbers are added to the new list.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #10
================================================================================

================================================================================
Test Case ID: 10
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Calculator
{
    public int Add(int a, int b)
    {


GOLDEN COMPLETION:
----------------------------------------
        return a + b;


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == 7, "Addition result should be 7");
    }
}

public class Program
{
    public static void Main()
    {
        Calculator calc = new Calculator();
        int result = calc.Add(3, 4);
        Debug.Assert(result == 7, "Main: Addition result should be 7");
    }
}


JUSTIFICATION:
----------------------------------------
This scenario tests the model's ability to recognize and complete a simple arithmetic operation within a method. The context is minimal, with only the method signature provided. The completion should correctly implement the addition operation, which is then verified by assertions in the suffix.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #11
================================================================================

================================================================================
Test Case ID: 11
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        Task<int> task = Task.Run(() =>
        {
            return 42;
        });


GOLDEN COMPLETION:
----------------------------------------
        int result = await task;


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == 42, "Task result should be 42");
        Console.WriteLine("Task completed with result: " + result);
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and continue an async/await pattern with minimal context. The prefix establishes the setup for an asynchronous task, and the suffix includes assertions to verify the result of the task. The golden completion demonstrates the correct usage of the await keyword to obtain the result of the task. This pattern is widely used in C# for asynchronous programming.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #12
================================================================================

================================================================================
Test Case ID: 12
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        int[] numbers = { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        int sum = 0;
        foreach (var num in numbers)
        {
            sum += num;
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(sum == 15, "Sum should be 15");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize a common iterator and collection pattern. The prefix establishes an array and the suffix asserts the sum of the array elements, making it clear that a loop is needed to sum the elements. The completion must fill in the iteration logic correctly. This scenario is simple yet effective in testing the model's ability to continue a basic but universally recognized pattern in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #13
================================================================================

================================================================================
Test Case ID: 13
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        try
        {


GOLDEN COMPLETION:
----------------------------------------
            throw new InvalidOperationException("Operation is not valid.");


SUFFIX CODE:
----------------------------------------
        }
        catch (InvalidOperationException ex)
        {
            Debug.Assert(ex.Message == "Operation is not valid.", "Unexpected exception message");
        }
        catch (Exception ex)
        {
            Debug.Assert(false, "Unexpected exception type: " + ex.GetType().Name);
        }
    }
}


JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate the LLM's ability to recognize and complete a common error handling pattern in C#. The try block is set up to throw a specific exception, and the catch block is designed to validate that the correct exception type and message are handled. This scenario tests the model's understanding of exception handling and assertion usage within minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #14
================================================================================

================================================================================
Test Case ID: 14
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        Func<int, int, int> add = 

GOLDEN COMPLETION:
----------------------------------------
(x, y) => x + y

SUFFIX CODE:
----------------------------------------
;
        int result = add(2, 3);
        Debug.Assert(result == 5, "The add function should return 5 when given 2 and 3.");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a simple delegate pattern with a lambda expression. The prefix sets up a Func delegate, and the golden completion requires the model to complete the lambda function correctly. The suffix includes an assertion to verify the correctness of the lambda function, ensuring that it adheres to the expected pattern and functionality.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #15
================================================================================

================================================================================
Test Case ID: 15
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main()
    {
        int[] numbers = { 1, 2, 3, 4, 5 };
        int sum = 0;
        foreach (int number in numbers)
        {


GOLDEN COMPLETION:
----------------------------------------
            sum += number;


SUFFIX CODE:
----------------------------------------
        }
        Debug.Assert(sum == 15, "Sum should be 15");
    }
}


JUSTIFICATION:
----------------------------------------
This test case checks the LLM's ability to recognize and complete a common pattern of summing elements in a collection using a foreach loop. The context is minimal but should be sufficient for the model to infer the pattern. The prefix sets up the loop and the suffix includes an assertion to verify the correct sum, ensuring the model completes the pattern correctly without duplicating any code in the suffix.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #16
================================================================================

================================================================================
Test Case ID: 16
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.IO;

public class ResourceExample
{
    public void WriteToFile(string path, string content)
    {

GOLDEN COMPLETION:
----------------------------------------
        using (StreamWriter writer = new StreamWriter(path))
        {
            writer.Write(content);
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(File.Exists(path), "File should exist after writing.");
        string writtenContent = File.ReadAllText(path);
        Debug.Assert(writtenContent == "Hello, World!", "Content should match the written text.");
    }
}

public class Program
{
    public static void Main()
    {
        string path = "testfile.txt";
        var example = new ResourceExample();
        example.WriteToFile(path, "Hello, World!");
        File.Delete(path);
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and continue a common resource management pattern using 'using' statements for automatic disposal of resources. The prefix sets up the method signature and the context of writing to a file, while the suffix includes assertions to verify the correct behavior. The golden completion involves the proper use of the 'using' statement to manage the StreamWriter resource.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #17
================================================================================

================================================================================
Test Case ID: 17
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Program
{
    public static void Main(string[] args)
    {
        int numerator = 10;
        int denominator = 2;


GOLDEN COMPLETION:
----------------------------------------
        int result = Divide(numerator, denominator);


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == 5, "Division result should be 5");
        denominator = 0;
        try
        {
            result = Divide(numerator, denominator);
        }
        catch (DivideByZeroException)
        {
            Debug.Assert(true, "Caught expected DivideByZeroException");
        }
    }

    public static int Divide(int a, int b)
    {
        return a / b;
    }
}


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to recognize and complete a common error handling pattern. The prefix sets up a division operation, and the golden completion involves performing this division. The suffix then includes assertions to verify correct behavior both for a valid division and handling a division by zero exception. This is a minimal context example that requires understanding of exception handling in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #18
================================================================================

================================================================================
Test Case ID: 18
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Threading.Tasks;

class Program
{
    static async Task Main(string[] args)
    {
        Task<int> task = Task.Run(() => 42);


GOLDEN COMPLETION:
----------------------------------------
        int result = await task;


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == 42, "Task result should be 42");
        Console.WriteLine("Task completed successfully");
    }
}


JUSTIFICATION:
----------------------------------------
This test case evaluates the model's ability to recognize and complete an async/await pattern with minimal context. The context provided includes an async method that initiates a task, with the expected completion involving awaiting the task's result. The assertion checks if the task's result is as expected, ensuring the correct usage of async/await.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #19
================================================================================

================================================================================
Test Case ID: 19
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.IO;

public class ResourceManagementExample
{
    public void ManageResource()
    {


GOLDEN COMPLETION:
----------------------------------------
        using (StreamReader reader = new StreamReader("example.txt"))
        {
            string content = reader.ReadToEnd();
            Debug.Assert(!string.IsNullOrEmpty(content), "File content should not be empty");
        }


SUFFIX CODE:
----------------------------------------
    }
}

public class Program
{
    public static void Main()
    {
        ResourceManagementExample example = new ResourceManagementExample();
        example.ManageResource();
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a resource management pattern using the 'using' statement in C#. The 'using' statement ensures that resources are properly disposed of, which is a common and essential pattern in C#. The example provides minimal context but still allows for the correct completion of the pattern. The assertions verify the functionality by checking that the file content is not empty.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #20
================================================================================

================================================================================
Test Case ID: 20
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.IO;

class ResourceManagementExample
{
    public void ProcessFile(string filePath)
    {


GOLDEN COMPLETION:
----------------------------------------
        string result;
        using (StreamReader reader = new StreamReader(filePath))
        {
            result = "File processed";
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == "File processed", "The file was not processed correctly");
    }
}

class Program
{
    static void Main()
    {
        ResourceManagementExample example = new ResourceManagementExample();
        example.ProcessFile("test.txt");
    }
}


JUSTIFICATION:
----------------------------------------
This scenario tests the model's ability to recognize and complete a common resource management pattern using the 'using' statement for handling IDisposable resources. The prefix sets up the context by defining a method that processes a file, while the suffix includes an assertion to verify the correct functionality and the necessary cleanup. The golden completion demonstrates the proper use of the 'using' statement to ensure the StreamReader is disposed of correctly. This pattern is widely used and should be recognizable with minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #21
================================================================================

================================================================================
Test Case ID: 21
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class Program
{
    public static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
        List<int> squaredNumbers = new List<int>();


GOLDEN COMPLETION:
----------------------------------------
        foreach (var number in numbers)
        {
            squaredNumbers.Add(number * number);
        }


SUFFIX CODE:
----------------------------------------
        foreach (var num in squaredNumbers)
        {
            Debug.Assert(num == (num / (int)Math.Sqrt(num)) * (int)Math.Sqrt(num), "Number is not a perfect square");
        }
    }
}


JUSTIFICATION:
----------------------------------------
This is a good test case for iterator and collection patterns. The prefix sets up a common scenario where a list of numbers needs to be transformed. The golden completion involves a common pattern of iterating over a collection and modifying another collection based on the iteration. The suffix includes assertions to check the correctness of the transformation, ensuring the pattern is recognizable with minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #22
================================================================================

================================================================================
Test Case ID: 22
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        var result = numbers.ConvertAll(x => x * 2);


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result.Count == 5, "Result count should be 5");
        Debug.Assert(result[0] == 2, "First element should be 2");
        Debug.Assert(result[4] == 10, "Last element should be 10");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a common collection transformation pattern using ConvertAll method on a List<T>. The prefix provides minimal context, establishing a list of integers and the start of a method. The completion requires the model to recognize the need to transform the list elements using a lambda expression, which is a common use case. The suffix includes assertions to validate that the transformation was performed correctly and ensures the pattern is applied as expected.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #23
================================================================================

================================================================================
Test Case ID: 23
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        int number = 10;


GOLDEN COMPLETION:
----------------------------------------
        int result = 0;
        for (int i = 1; i <= number; i++)
        {
            result += i;
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result == 55, "The sum of the first 10 natural numbers should be 55");
        Console.WriteLine("Sum calculated correctly.");
    }
}


JUSTIFICATION:
----------------------------------------
This is a good test case because it tests the ability to recognize and complete a common algorithm pattern - summing the first 'n' natural numbers. The prefix sets up the context with the variable and method signature, while the golden_completion contains the loop logic. The suffix contains assertions to verify the result and ensures proper output, making the pattern clear and identifiable with minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #24
================================================================================

================================================================================
Test Case ID: 24
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        int[] numbers = { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        var evenNumbers = System.Linq.Enumerable.Where(numbers, n => n % 2 == 0);


SUFFIX CODE:
----------------------------------------
        foreach (var num in evenNumbers)
        {
            Debug.Assert(num % 2 == 0, "Number is not even");
        }
        Console.WriteLine("All numbers are even.");
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and continue an iterator and collection pattern using LINQ. The prefix sets up an array of integers and the suffix contains a foreach loop with assertions to verify even numbers. The golden completion requires the model to insert the LINQ statement to filter even numbers, a common and recognizable pattern in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #25
================================================================================

================================================================================
Test Case ID: 25
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Program
{
    public static void Main()
    {
        Func<int, int, int> add = 

GOLDEN COMPLETION:
----------------------------------------
(x, y) => x + y

SUFFIX CODE:
----------------------------------------
;
        int result = add(3, 4);
        Debug.Assert(result == 7, "Addition result should be 7");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a delegate pattern. The prefix sets up a functional programming scenario using a Func delegate. The suffix includes an assertion to verify that the delegate correctly implements addition. This scenario is common and the pattern should be easily recognizable with minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #26
================================================================================

================================================================================
Test Case ID: 26
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {


GOLDEN COMPLETION:
----------------------------------------
        int result = PerformCalculation(2, 3);
        Console.WriteLine(result);


SUFFIX CODE:
----------------------------------------
        Debug.Assert(PerformCalculation(2, 3) == 5, "Test Case 1 Failed");
        Debug.Assert(PerformCalculation(-1, 1) == 0, "Test Case 2 Failed");
        Debug.Assert(PerformCalculation(0, 0) == 0, "Test Case 3 Failed");
    }

    static int PerformCalculation(int a, int b)
    {
        return a + b;
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize a simple mathematical operation pattern, specifically the addition of two integers. The context is minimal, with only a method signature and a call to the method provided. The expected behavior is clear and follows standard conventions, making it a good test for low-context pattern recognition.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #27
================================================================================

================================================================================
Test Case ID: 27
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
        IEnumerable<int> evens = FilterEvenNumbers(numbers);


GOLDEN COMPLETION:
----------------------------------------
        foreach (int number in numbers)
        {
            if (number % 2 == 0)
            {
                yield return number;
            }
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(evens.GetEnumerator().MoveNext() && evens.GetEnumerator().Current == 2, "First even number should be 2");
        Debug.Assert(evens.GetEnumerator().MoveNext() && evens.GetEnumerator().Current == 4, "Second even number should be 4");
        Debug.Assert(!evens.GetEnumerator().MoveNext(), "No more even numbers should be present");
    }

    static IEnumerable<int> FilterEvenNumbers(IEnumerable<int> numbers)
    {
        foreach (int number in numbers)
        {
            if (number % 2 == 0)
            {
                yield return number;
            }
        }
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a common iterator pattern for filtering a collection. The prefix sets up a list of integers, and the suffix includes assertions to verify the correct even numbers are returned. The golden completion involves yielding even numbers, which is a standard pattern for filtering collections.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #28
================================================================================

================================================================================
Test Case ID: 28
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

class Program
{
    static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };
        IEnumerator<int> enumerator = numbers.GetEnumerator();


GOLDEN COMPLETION:
----------------------------------------
        enumerator.MoveNext();


SUFFIX CODE:
----------------------------------------
        Debug.Assert(enumerator.MoveNext(), "First MoveNext() should return true");
        Debug.Assert(enumerator.Current == 1, "First element should be 1");
        Debug.Assert(enumerator.MoveNext(), "Second MoveNext() should return true");
        Debug.Assert(enumerator.Current == 2, "Second element should be 2");
        enumerator.Dispose();
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a pattern involving the use of an enumerator to iterate over a collection. The prefix sets up the collection and enumerator, and the suffix contains assertions that verify the correct behavior of the enumerator after moving to the next element. The golden completion requires the LLM to identify that moving the enumerator to the next element is the next logical step in the pattern.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #29
================================================================================

================================================================================
Test Case ID: 29
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Collections.Generic;

public class Program
{
    public static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5 };


GOLDEN COMPLETION:
----------------------------------------
        numbers.Add(6);


SUFFIX CODE:
----------------------------------------
        int sum = 0;
        foreach (var number in numbers)
        {
            sum += number;
        }
        Debug.Assert(sum == 21, "Sum should be 21");
    }
}


JUSTIFICATION:
----------------------------------------
This test case focuses on iterator and collection patterns in C#. It tests the model's ability to recognize and continue a pattern of manipulating and iterating through a collection. The prefix sets up a list and the beginning of the Main method, while the suffix includes assertions to verify the integrity of the collection and its sum. The model must correctly continue the pattern of modifying the collection to ensure the final sum is as expected.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #30
================================================================================

================================================================================
Test Case ID: 30
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Collections.Generic;

public class Program
{
    public static IEnumerable<int> GenerateSequence()
    {


GOLDEN COMPLETION:
----------------------------------------
        yield return 1;
        yield return 2;
        yield return 3;
    }

    public static void Main()
    {
        var sequence = GenerateSequence().GetEnumerator();
        Debug.Assert(sequence.MoveNext() && sequence.Current == 1, "First item should be 1");


SUFFIX CODE:
----------------------------------------
        Debug.Assert(sequence.MoveNext() && sequence.Current == 2, "Second item should be 2");
        Debug.Assert(sequence.MoveNext() && sequence.Current == 3, "Third item should be 3");
        Debug.Assert(!sequence.MoveNext(), "Sequence should end");
    }
}


JUSTIFICATION:
----------------------------------------
This is a good test case for evaluating an LLM's ability to recognize and continue an iterator pattern using 'yield return' with minimal context. The prefix sets up an iterator method, and the golden completion is expected to continue yielding a sequence. The suffix includes assertions to verify the correctness of the generated sequence, ensuring the model understands the iterator pattern.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #31
================================================================================

================================================================================
Test Case ID: 31
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Calculator
{
    public static int Multiply(int a, int b)
    {


GOLDEN COMPLETION:
----------------------------------------
        int result = a * b;


SUFFIX CODE:
----------------------------------------
        return result;
    }

    public static void Main()
    {
        int result = Multiply(3, 4);
        Debug.Assert(result == 12, "3 * 4 should be 12");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a multiplication operation within a method based on minimal context. The pattern involves a common mathematical operation (multiplication) and requires the model to correctly identify and implement the core logic of the method. The assertions ensure that the method returns the correct result, validating the pattern adherence and functionality.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #32
================================================================================

================================================================================
Test Case ID: 32
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Program
{
    public static void Main()
    {
        Func<int, int, string> func = (x, y) => 

GOLDEN COMPLETION:
----------------------------------------
((x, y) => (x + y).ToString())

SUFFIX CODE:
----------------------------------------
;
        Debug.Assert(func(2, 3) == "5", "The result should be 5");
        Debug.Assert(func(10, -5) == "5", "The result should be 5");
    }
}


JUSTIFICATION:
----------------------------------------
This is a good test case for recognizing and completing a functional programming pattern in C#. The completion involves creating a lambda function that sums two integers and returns the result as a string. The pattern is non-trivial and requires understanding the use of lambda expressions and the ToString method. Assertions verify correctness of the function output.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #33
================================================================================

================================================================================
Test Case ID: 33
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomCollection<T>
{
    private List<T> _items = new List<T>();

    public void AddItem(T item)
    {
        _items.Add(item);
    }

    public T GetItem(int index)
    {


GOLDEN COMPLETION:
----------------------------------------
        T result = _items[index];
        return result;


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result != null, "Item should not be null");
    }

    public static void Main()
    {
        var collection = new CustomCollection<string>();
        collection.AddItem("Test");
        var item = collection.GetItem(0);
        Debug.Assert(item == "Test", "Item should be 'Test'");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a common pattern in collection management with generics. The pattern involves adding and retrieving items from a generic list, which is a realistic use case. The context provided is minimal, requiring the model to understand the use of generics and collection methods. The suffix includes assertions to validate the correct implementation and ensure the pattern is followed correctly.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #34
================================================================================

================================================================================
Test Case ID: 34
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Example
{
    public delegate int MathOperation(int a, int b);

    public static int PerformOperation(MathOperation operation, int x, int y)
    {


GOLDEN COMPLETION:
----------------------------------------
        int result = operation(x, y);


SUFFIX CODE:
----------------------------------------
    }

    public static void Main()
    {
        MathOperation add = (a, b) => a + b;
        MathOperation subtract = (a, b) => a - b;
        int result1 = PerformOperation(add, 10, 5);
        int result2 = PerformOperation(subtract, 7, 5);
        Debug.Assert(result1 == 15, "Addition result is incorrect");
        Debug.Assert(result2 == 2, "Subtraction result is incorrect");
    }
}


JUSTIFICATION:
----------------------------------------
This test case is designed to evaluate the model's ability to recognize and complete a delegate pattern in C#. The example uses a delegate to perform different mathematical operations, showcasing a common use of delegates and functional programming patterns in C#. The pattern is recognizable with minimal context, focusing on the correct usage of delegates and lambda expressions.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #35
================================================================================

================================================================================
Test Case ID: 35
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Program
{
    public static void Main()
    {
        Func<int, int> square = 

GOLDEN COMPLETION:
----------------------------------------
x => x * x

SUFFIX CODE:
----------------------------------------
;
        Debug.Assert(square(2) == 4, "Square of 2 should be 4");
        Debug.Assert(square(3) == 9, "Square of 3 should be 9");
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a simple functional programming pattern using a delegate. The lambda expression for squaring a number is a common pattern in functional programming, and the assertions validate its correctness. The minimal context provided ensures the model must understand the lambda expression syntax and its application in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #36
================================================================================

================================================================================
Test Case ID: 36
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static void Main(string[] args)
    {
        Func<int, int, bool> isEqual = 

GOLDEN COMPLETION:
----------------------------------------
(a, b) => a == b

SUFFIX CODE:
----------------------------------------
;
        Debug.Assert(isEqual(3, 3), "3 and 3 should be equal");
        Debug.Assert(!isEqual(3, 4), "3 and 4 should not be equal");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a functional programming pattern in C# using delegates. The scenario involves defining a lambda function that checks for equality between two integers. The pattern is clear yet non-trivial, and the surrounding context is minimal, making it a good test of the model's ability to infer the correct logic. The suffix includes assertions to verify the correctness of the lambda function, ensuring that it behaves as expected. This tests the model's understanding of functional programming constructs and lambda expressions in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #37
================================================================================

================================================================================
Test Case ID: 37
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomCollection<T>
{
    private List<T> items = new List<T>();

    public void Add(T item)
    {
        items.Add(item);
    }

    public IEnumerable<T> Filter(Func<T, bool> predicate)
    {


GOLDEN COMPLETION:
----------------------------------------
        foreach (var item in items)
        {
            if (predicate(item))
            {
                yield return item;
            }
        }


SUFFIX CODE:
----------------------------------------
    }
}

public class Program
{
    public static void Main()
    {
        var collection = new CustomCollection<int>();
        collection.Add(1);
        collection.Add(2);
        collection.Add(3);

        var filteredItems = collection.Filter(x => x % 2 == 0);
        int count = 0;
        foreach (var item in filteredItems)
        {
            Debug.Assert(item % 2 == 0, "Item should be even");
            count++;
        }
        Debug.Assert(count == 1, "There should be exactly one even item");
    }
}


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to recognize and complete a custom iterator pattern using the 'yield return' keyword. The prefix establishes a class with a generic collection and a method signature for filtering items. The required completion involves iterating over the collection and yielding items that match a predicate. This pattern is non-trivial and requires an understanding of C# iterators and lambda expressions. The suffix contains usage of the filter method, iterating over the results, and assertions to verify correctness, ensuring the LLM completes the pattern accurately.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #38
================================================================================

================================================================================
Test Case ID: 38
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Example {
    public void ProcessItems<T>(IEnumerable<T> items, Action<T> action) {

GOLDEN COMPLETION:
----------------------------------------
        foreach (var item in items) {
            action(item);
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(items != null, "items should not be null");
        Debug.Assert(action != null, "action should not be null");
    }

    public static void Main() {
        var example = new Example();
        var numbers = new List<int> { 1, 2, 3, 4, 5 };
        example.ProcessItems(numbers, n => Console.WriteLine(n));
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a common pattern in C# where a generic method processes each item in a collection using an action delegate. The completion requires understanding of generics, delegates, and basic iteration patterns in C#. The prefix sets up the method signature and partial implementation, while the suffix contains assertions and test code that verifies the correct behavior of the method.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #39
================================================================================

================================================================================
Test Case ID: 39
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

public class Example
{
    public void ProcessData(Action<string> callback)
    {
        string data = "Sample data";
        Debug.Assert(callback != null, "Callback should not be null");
        Debug.Assert(callback.Method.Name == "WriteLine", "Callback should be WriteLine");


GOLDEN COMPLETION:
----------------------------------------
        callback(data);


SUFFIX CODE:
----------------------------------------
    }

    public static void Main()
    {
        Example example = new Example();
        example.ProcessData(Console.WriteLine);
    }
}


JUSTIFICATION:
----------------------------------------
This is a good test case for low-context pattern matching because it requires the model to recognize a common delegate usage pattern in C#. The callback pattern is widely used in event-driven programming and functional programming in C#. The completion involves passing a string to a callback function, which is a typical use case. The minimal context provided should be sufficient for recognizing this pattern, and the assertions verify that the callback is correctly invoked and not null.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #40
================================================================================

================================================================================
Test Case ID: 40
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Collections.Generic;

class Program
{
    static void Main(string[] args)
    {
        List<string> names = new List<string> { "Alice", "Bob", "Charlie" };


GOLDEN COMPLETION:
----------------------------------------
        List<string> result = new List<string>();
        foreach (var name in names)
        {
            result.Add($"Hello, {name}!");
        }


SUFFIX CODE:
----------------------------------------
        Debug.Assert(result.Contains("Hello, Alice!"), "Missing greeting for Alice");
        Debug.Assert(result.Contains("Hello, Bob!"), "Missing greeting for Bob");
        Debug.Assert(result.Contains("Hello, Charlie!"), "Missing greeting for Charlie");

        Console.WriteLine("All assertions passed.");
    }
}


JUSTIFICATION:
----------------------------------------
This test case evaluates the model's ability to recognize and complete a common iterator pattern involving collection processing and string interpolation. The prefix sets up a list of names, and the suffix includes assertions to check that each name has been correctly processed into a greeting. The completion involves iterating over the list and creating personalized greeting messages, which requires understanding of foreach loops and string interpolation in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #41
================================================================================

================================================================================
Test Case ID: 41
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;
using System.Collections.Generic;

public class CustomCollection<T> : IEnumerable<T> where T : class
{
    private List<T> _items = new List<T>();

    public void Add(T item)
    {
        _items.Add(item);
    }

    public IEnumerator<T> GetEnumerator()
    {
        return new CustomEnumerator(_items);
    }

    private class CustomEnumerator : IEnumerator<T>
    {
        private List<T> _items;
        private int _position = -1;

        public CustomEnumerator(List<T> items)
        {
            _items = items;
        }

        public bool MoveNext()
        {


GOLDEN COMPLETION:
----------------------------------------
            _position++;
            return (_position < _items.Count);


SUFFIX CODE:
----------------------------------------
        }

        public void Reset()
        {
            _position = -1;
        }

        public T Current
        {
            get
            {
                try
                {
                    return _items[_position];
                }
                catch (IndexOutOfRangeException)
                {
                    throw new InvalidOperationException();
                }
            }
        }

        object IEnumerator.Current => Current;

        public void Dispose()
        {
        }
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        return GetEnumerator();
    }
}

public class Program
{
    public static void Main()
    {
        var collection = new CustomCollection<string>();
        collection.Add("A");
        collection.Add("B");
        collection.Add("C");

        var enumerator = collection.GetEnumerator();

        Debug.Assert(enumerator.MoveNext(), "MoveNext failed at position 0");
        Debug.Assert(enumerator.Current == "A", "Current is not 'A'");

        Debug.Assert(enumerator.MoveNext(), "MoveNext failed at position 1");
        Debug.Assert(enumerator.Current == "B", "Current is not 'B'");

        Debug.Assert(enumerator.MoveNext(), "MoveNext failed at position 2");
        Debug.Assert(enumerator.Current == "C", "Current is not 'C'");

        Debug.Assert(!enumerator.MoveNext(), "MoveNext should return false at the end");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete the pattern for implementing a custom IEnumerator<T> in C#. The prefix sets up a custom collection and enumerator, while the suffix verifies the implementation through assertions. The completion requires understanding the iterator pattern and correctly implementing the MoveNext method.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #42
================================================================================

================================================================================
Test Case ID: 42
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections;
using System.Collections.Generic;
using System.Diagnostics;

public class PaginatedIterator<T> : IEnumerable<T>
{
    private readonly List<T> _items;
    private readonly int _pageSize;

    public PaginatedIterator(List<T> items, int pageSize)
    {
        _items = items;
        _pageSize = pageSize;
    }

    public IEnumerator<T> GetEnumerator()
    {
        return new PageEnumerator(this);
    }

    IEnumerator IEnumerable.GetEnumerator()
    {
        return GetEnumerator();
    }

    private class PageEnumerator : IEnumerator<T>
    {
        private readonly PaginatedIterator<T> _iterator;
        private int _currentIndex = -1;
        private int _currentPage = 0;

        public PageEnumerator(PaginatedIterator<T> iterator)
        {
            _iterator = iterator;
        }

        public bool MoveNext()
        {

GOLDEN COMPLETION:
----------------------------------------
            _currentIndex++;
            if (_currentIndex >= (_currentPage + 1) * _iterator._pageSize)
            {
                _currentPage++;
                if (_currentIndex >= _iterator._items.Count)
                {
                    return false;
                }
            }
            return true;


SUFFIX CODE:
----------------------------------------
        }

        public void Reset()
        {
            _currentIndex = -1;
            _currentPage = 0;
        }

        public T Current
        {
            get
            {
                return _iterator._items[_currentIndex];
            }
        }

        object IEnumerator.Current => Current;

        public void Dispose() { }
    }
}

public class Program
{
    public static void Main()
    {
        List<int> numbers = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
        PaginatedIterator<int> paginatedIterator = new PaginatedIterator<int>(numbers, 3);
        int count = 0;
        foreach (var number in paginatedIterator)
        {
            count++;
        }
        Debug.Assert(count == 10, "Expected to iterate through all items in the list");
    }
}


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to recognize and complete a custom iterator pattern with complex yield logic. The PaginatedIterator class divides a list into pages, iterating through items page by page. The MoveNext method includes logic to handle transitions between pages, making it a good test for understanding stateful iterators and lazy evaluation.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #43
================================================================================

================================================================================
Test Case ID: 43
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomCollection<T>
{
    private readonly List<T> _items = new List<T>();

    public void Add(T item)
    {
        _items.Add(item);
    }

    public IEnumerator<T> GetEnumerator()
    {


GOLDEN COMPLETION:
----------------------------------------
        foreach (var item in _items)
        {
            yield return item;
        }


SUFFIX CODE:
----------------------------------------
    }
}

public class Program
{
    public static void Main()
    {
        var collection = new CustomCollection<int>();
        collection.Add(1);
        collection.Add(2);
        collection.Add(3);
        var enumerator = collection.GetEnumerator();
        Debug.Assert(enumerator.MoveNext() && enumerator.Current == 1, "First item should be 1");
        Debug.Assert(enumerator.MoveNext() && enumerator.Current == 2, "Second item should be 2");
        Debug.Assert(enumerator.MoveNext() && enumerator.Current == 3, "Third item should be 3");
        Debug.Assert(!enumerator.MoveNext(), "No more items should be present");
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a common pattern for implementing a custom collection with an iterator. The code demonstrates the correct usage of an iterator pattern, requiring the model to understand the use of yield return within a foreach loop over a collection. Assertions in the suffix ensure that the iterator correctly iterates over all items in the collection, verifying both the order and presence of items.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #44
================================================================================

================================================================================
Test Case ID: 44
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    delegate int Operation(int x, int y);

    static void Main()
    {
        Operation add = (x, y) => x + y;
        Operation multiply = (x, y) => x * y;


GOLDEN COMPLETION:
----------------------------------------
        Operation subtract = (x, y) => x - y;
        Operation divide = (x, y) => x / y;


SUFFIX CODE:
----------------------------------------
        int sum = add(3, 4);
        int product = multiply(3, 4);
        Debug.Assert(sum == 7, "Sum should be 7");
        Debug.Assert(product == 12, "Product should be 12");
    }
}


JUSTIFICATION:
----------------------------------------
This example demonstrates a pattern of using delegates for basic arithmetic operations. The prefix sets up the context with addition and multiplication operations, and the golden completion introduces subtraction and division operations. The suffix contains assertions that verify the correctness of the operations, ensuring the model understands the pattern of defining and using delegates for arithmetic functions. This scenario tests the model's ability to recognize and extend a pattern with minimal context.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #45
================================================================================

================================================================================
Test Case ID: 45
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomEnumerator<T>
{
    private readonly List<T> _items;
    public CustomEnumerator(List<T> items)
    {
        _items = items;
    }
    public IEnumerator<T> GetEnumerator()
    {
        for (int i = 0; i < _items.Count; i++)
        {


GOLDEN COMPLETION:
----------------------------------------
            yield return _items[i];


SUFFIX CODE:
----------------------------------------
        }
    }

    public static void Main()
    {
        var items = new List<int> { 1, 2, 3, 4, 5 };
        var enumerator = new CustomEnumerator<int>(items);
        var result = new List<int>();
        foreach (var item in enumerator.GetEnumerator())
        {
            result.Add(item);
        }
        Debug.Assert(result.Count == 5, "Count should be 5");
        Debug.Assert(result[0] == 1, "First item should be 1");
        Debug.Assert(result[4] == 5, "Last item should be 5");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a custom enumerator pattern using yield return. The prefix sets up the structure, and the completion involves iterating over a list to yield each item. The suffix contains assertions to verify the enumerator's correctness, ensuring that the model can complete the pattern accurately. This scenario involves understanding deferred execution and custom iterator patterns, which are advanced C# concepts.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #46
================================================================================

================================================================================
Test Case ID: 46
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Diagnostics;

class Program
{
    static Func<int, int> CreateMultiplier(int factor)
    {


GOLDEN COMPLETION:
----------------------------------------
        return x => x * factor;


SUFFIX CODE:
----------------------------------------
        Func<int, int> multiplier = CreateMultiplier(5);
        Debug.Assert(multiplier(2) == 10, "Multiplier function failed");
        Debug.Assert(multiplier(3) == 15, "Multiplier function failed");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a functional programming pattern, specifically the creation of a closure that captures an external variable. The pattern involves returning a lambda function that uses the captured variable, which is a common use case in C#. The prefix sets up the method signature and context, the golden completion provides the lambda function definition, and the suffix includes assertions to verify the correct behavior of the closure. This scenario requires understanding of closures and lambda expressions in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #47
================================================================================

================================================================================
Test Case ID: 47
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomPaginator<T>
{
    private readonly List<T> _items;
    private readonly int _pageSize;

    public CustomPaginator(List<T> items, int pageSize)
    {
        _items = items;
        _pageSize = pageSize;
    }

    public IEnumerable<IEnumerable<T>> GetPages()
    {

GOLDEN COMPLETION:
----------------------------------------
        for (int i = 0; i < _items.Count; i += _pageSize)
        {
            yield return _items.GetRange(i, Math.Min(_pageSize, _items.Count - i));


SUFFIX CODE:
----------------------------------------
        }
    }
}

public class Test
{
    public static void Main()
    {
        var items = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
        var paginator = new CustomPaginator<int>(items, 3);
        var pages = paginator.GetPages();
        var pageList = new List<List<int>>(pages);

        Debug.Assert(pageList.Count == 3, "Expected 3 pages.");
        Debug.Assert(pageList[0].Count == 3, "Expected 3 items in the first page.");
        Debug.Assert(pageList[1].Count == 3, "Expected 3 items in the second page.");
        Debug.Assert(pageList[2].Count == 3, "Expected 3 items in the third page.");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to complete a custom paginator implementation, which involves iterating over a collection and yielding pages of items. The paginator pattern is common in production code for handling large datasets in manageable chunks. The provided prefix sets up the context with the class and method definitions, while the suffix includes assertions to verify that the paginator correctly divides the list into pages. This scenario requires understanding of iterators, yield statements, and collection manipulation in C#.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #48
================================================================================

================================================================================
Test Case ID: 48
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class PagedEnumerator<T> : IEnumerator<T>
{
    private readonly IList<T> _collection;
    private readonly int _pageSize;
    private int _currentPage;
    private int _currentIndex;

    public PagedEnumerator(IList<T> collection, int pageSize)
    {
        _collection = collection;
        _pageSize = pageSize;
        _currentPage = 0;
        _currentIndex = -1;
    }


GOLDEN COMPLETION:
----------------------------------------
    public bool MoveNext()
    {
        _currentIndex++;
        if (_currentIndex >= _pageSize)
        {
            _currentPage++;
            _currentIndex = 0;
        }
        return _currentPage * _pageSize + _currentIndex < _collection.Count;
    }


SUFFIX CODE:
----------------------------------------
    public void Reset()
    {
        _currentPage = 0;
        _currentIndex = -1;
    }

    public T Current => _collection[_currentPage * _pageSize + _currentIndex];

    object System.Collections.IEnumerator.Current => Current;

    public void Dispose() {}
}

public class Program
{
    public static void Main()
    {
        var data = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
        var enumerator = new PagedEnumerator<int>(data, 3);
        var results = new List<int>();
        while (enumerator.MoveNext())
        {
            results.Add(enumerator.Current);
        }
        Debug.Assert(results.Count == 9, "All elements should be iterated.");
        Debug.Assert(results[0] == 1 && results[8] == 9, "The elements should be in order.");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a custom IEnumerator<T> implementation pattern with complex state handling. The MoveNext() method requires understanding of pagination logic, proper state management, and correct return value semantics. This is a non-trivial pattern often encountered in production code for handling batched or paged data processing. The pattern is clear and recognizable with minimal context, and the provided assertions ensure the implementation follows the intended logic and handles edge cases correctly.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #49
================================================================================

================================================================================
Test Case ID: 49
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomEnumerator<T>
{
    private readonly List<T> _collection;
    private int _currentIndex;

    public CustomEnumerator(List<T> collection)
    {
        _collection = collection;
        _currentIndex = -1;
    }

    public bool MoveNext()
    {


GOLDEN COMPLETION:
----------------------------------------
        _currentIndex++;


SUFFIX CODE:
----------------------------------------
        return _currentIndex < _collection.Count - 1;
    }

    public T Current => _collection[_currentIndex];
}

public class Program
{
    public static void Main()
    {
        var list = new List<int> { 1, 2, 3 };
        var enumerator = new CustomEnumerator<int>(list);
        while (enumerator.MoveNext())
        {
            Debug.Assert(enumerator.Current == list[enumerator.Current - 1], "Current value does not match expected value.");
        }
    }
}

JUSTIFICATION:
----------------------------------------
This example tests the model's ability to recognize and complete a custom enumerator pattern in C#. The enumerator pattern is widely used and involves maintaining state with an index and checking for bounds. The golden completion focuses on updating the current index, which is crucial for the MoveNext method to function correctly. This pattern is common in production code and requires understanding of iteration state management.

ASSERTIONS:
----------------------------------------

================================================================================

================================================================================
Test Case #50
================================================================================

================================================================================
Test Case ID: 50
Source: devbench-low-context
Language: c_sharp
================================================================================

PREFIX CODE:
----------------------------------------
using System;
using System.Collections.Generic;
using System.Diagnostics;

public class CustomEnumerator<T>
{
    private readonly List<T> _items;
    public CustomEnumerator(List<T> items)
    {
        _items = items;
    }
    public IEnumerator<T> GetEnumerator()
    {
        for (int i = 0; i < _items.Count; i++)
        {
            if (i % 2 == 0)
            {

GOLDEN COMPLETION:
----------------------------------------
                yield return _items[i];

SUFFIX CODE:
----------------------------------------
            }
        }
    }
}

public static class Program
{
    public static void Main(string[] args)
    {
        var items = new List<int> { 1, 2, 3, 4, 5 };
        var enumerator = new CustomEnumerator<int>(items);
        var result = new List<int>();
        foreach (var item in enumerator.GetEnumerator())
        {
            result.Add(item);
        }
        Debug.Assert(result.Count == 3, "Expected 3 items");
        Debug.Assert(result[0] == 1, "Expected first item to be 1");
        Debug.Assert(result[1] == 3, "Expected second item to be 3");
        Debug.Assert(result[2] == 5, "Expected third item to be 5");
    }
}


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to recognize and complete a custom iterator pattern in C#. The pattern involves implementing an enumerator that returns every second item from a list, a non-trivial task that requires understanding of yield statements and custom iteration logic. The prefix establishes the context of the class and method, while the suffix verifies the implementation with assertions. This scenario ensures the model understands advanced iterator patterns and can generate correct, executable code.

ASSERTIONS:
----------------------------------------

================================================================================
