
================================================================================
Test Case #1
================================================================================

================================================================================
Test Case ID: 1
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def find_max(nums):
    """Find the maximum value in a list of integers."""


GOLDEN COMPLETION:
----------------------------------------
    if not nums:
        raise ValueError('The list is empty')
    max_value = nums[0]
    for num in nums:
        if num > max_value:
            max_value = num
    return max_value


SUFFIX CODE:
----------------------------------------

def test_find_max():
    # Test with a list of positive integers
    assert find_max([1, 2, 3, 4, 5]) == 5
    # Test with a list containing negative integers
    assert find_max([-10, -5, -1, -3]) == -1
    # Test with a list containing both positive and negative integers
    assert find_max([-10, 5, 0, 3]) == 5

    print("All tests passed.")

test_find_max()


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to translate a comment into code and vice versa. The function `find_max` is documented to find the maximum value in a list of integers, and the golden completion provides the corresponding implementation. The suffix contains a test suite that verifies the function's correctness with various input scenarios, including edge cases. The assertions ensure the function behaves as expected, and the documentation is accurate. This setup effectively tests the LLM's understanding of code functionality and documentation clarity.

ASSERTIONS:
----------------------------------------
assert find_max([1, 2, 3, 4, 5]) == 5
assert find_max([-10, -5, -1, -3]) == -1
assert find_max([-10, 5, 0, 3]) == 5
try:
    find_max([])
except ValueError as e:
    assert str(e) == 'The list is empty'
================================================================================

================================================================================
Test Case #2
================================================================================

================================================================================
Test Case ID: 2
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def calculate_factorial(n):
    """Calculates the factorial of a given number n."""
    if n < 0:
        raise ValueError("Factorial is not defined for negative numbers")
    elif n == 0:
        return 1
    else:


GOLDEN COMPLETION:
----------------------------------------
        return n * calculate_factorial(n - 1)


SUFFIX CODE:
----------------------------------------


try:
    assert calculate_factorial(5) == 120
    assert calculate_factorial(0) == 1
    assert calculate_factorial(3) == 6
    assert calculate_factorial(1) == 1
    # Test for negative input
    try:
        calculate_factorial(-1)
    except ValueError as e:
        assert str(e) == "Factorial is not defined for negative numbers"
finally:
    pass  # Cleanup code can be added here if needed

JUSTIFICATION:
----------------------------------------
This example tests both code-to-comment and comment-to-code translation capabilities. The prompt includes a partial implementation of a factorial calculation function with a clear docstring explaining its purpose. The golden_completion requires translating this partial code into a recursive implementation of the factorial calculation. The suffix then completes the function using an iterative approach and includes various assertions to test the function's correctness. This scenario effectively tests the model's ability to understand and generate documentation as well as complete code accurately.

ASSERTIONS:
----------------------------------------
try:
    assert calculate_factorial(5) == 120
    assert calculate_factorial(0) == 1
    assert calculate_factorial(3) == 6
    assert calculate_factorial(1) == 1
    # Test for negative input
    try:
        calculate_factorial(-1)
    except ValueError as e:
        assert str(e) == "Factorial is not defined for negative numbers"
finally:
    pass  # Cleanup code can be added here if needed
================================================================================

================================================================================
Test Case #3
================================================================================

================================================================================
Test Case ID: 3
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# This function calculates the factorial of a number recursively.
def factorial(n):
    if n == 0:
        return 1
    else:


GOLDEN COMPLETION:
----------------------------------------
        return n * factorial(n-1)

SUFFIX CODE:
----------------------------------------

# Test the factorial function
result = factorial(5)
assert result == 120, f"Expected 120 but got {result}"

result = factorial(0)
assert result == 1, f"Expected 1 but got {result}"

# Cleanup code (if any) would go here


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to translate between code and comments. The prompt introduces a factorial function and the completion requires translating a recursive step. The suffix includes tests that check the correctness of the implementation, ensuring that the LLM's translation is correct. This scenario is a good test case because it involves understanding recursion, proper indentation, and accurate comment-to-code translation.

ASSERTIONS:
----------------------------------------
result = factorial(5)
assert result == 120, f"Expected 120 but got {result}"

result = factorial(0)
assert result == 1, f"Expected 1 but got {result}"

================================================================================

================================================================================
Test Case #4
================================================================================

================================================================================
Test Case ID: 4
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class Portfolio:
    def __init__(self):
        self.stocks = {}

    def add_stock(self, name: str, shares: int, price: float):
        """
        Add a stock to the portfolio.

        Parameters:
        name (str): The name of the stock.
        shares (int): The number of shares to add.
        price (float): The purchase price per share.
        """
        if name in self.stocks:
            current_shares, current_price = self.stocks[name]
            new_shares = current_shares + shares
            new_price = (current_price * current_shares + price * shares) / new_shares
            self.stocks[name] = (new_shares, new_price)
        else:
            self.stocks[name] = (shares, price)

    def get_stock_value(self, name: str) -> float:
        """
        Get the total value of a specific stock in the portfolio.

        Parameters:
        name (str): The name of the stock.

        Returns:
        float: The total value of the stock.
        """


GOLDEN COMPLETION:
----------------------------------------
        shares, price = self.stocks.get(name, (0, 0.0))


SUFFIX CODE:
----------------------------------------
        return shares * price

    def total_value(self) -> float:
        """
        Calculate the total value of the entire portfolio.

        Returns:
        float: The total portfolio value.
        """
        total = 0.0
        for shares, price in self.stocks.values():
            total += shares * price
        return total

# Example usage
portfolio = Portfolio()
portfolio.add_stock('AAPL', 10, 150.0)
portfolio.add_stock('GOOGL', 5, 1000.0)
assert portfolio.get_stock_value('AAPL') == 1500.0
assert portfolio.total_value() == 6500.0


JUSTIFICATION:
----------------------------------------
This test case is a good example because it covers a realistic business scenario of managing a portfolio of stocks. The completion involves retrieving stock information, which is a common operation. The test ensures accurate translation between code and documentation by verifying the correctness of the business logic and the completeness of the docstrings. Key terms like 'Parameters' and 'Returns' are checked in the docstring assertions, and the functionality is validated with realistic usage examples.

ASSERTIONS:
----------------------------------------
assert 'get the total value of a specific stock in the portfolio' in Portfolio.get_stock_value.__doc__.lower()
assert 'parameters' in Portfolio.get_stock_value.__doc__.lower()
assert 'returns' in Portfolio.get_stock_value.__doc__.lower()
assert 'name (str): the name of the stock' in Portfolio.get_stock_value.__doc__.lower()
assert 'float: the total value of the stock' in Portfolio.get_stock_value.__doc__.lower()
assert portfolio.get_stock_value('AAPL') == 1500.0
assert portfolio.total_value() == 6500.0

================================================================================

================================================================================
Test Case #5
================================================================================

================================================================================
Test Case ID: 5
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# Function to assess risk based on portfolio data
# Parameters:
# - portfolio (dict): A dictionary where keys are asset names and values are their respective values
# - threshold (float): The risk threshold value
# Returns:
# - bool: True if the total value of the portfolio exceeds the threshold, False otherwise

def assess_risk(portfolio, threshold):

GOLDEN COMPLETION:
----------------------------------------
    """
    Calculate the total value of the portfolio and compare it to the threshold.

    Parameters:
    - portfolio (dict): A dictionary where keys are asset names and values are their respective values
    - threshold (float): The risk threshold value

    Returns:
    - bool: True if the total value of the portfolio exceeds the threshold, False otherwise
    """


SUFFIX CODE:
----------------------------------------
    total_value = sum(portfolio.values())
    return total_value > threshold

# Example usage
portfolio = {'stocks': 100000, 'bonds': 50000, 'real_estate': 200000}
threshold = 300000
risk = assess_risk(portfolio, threshold)
print(f'Risk Assessment: {risk}')

# Clean up resources if any
# (In this case, there are no resources to clean up)


JUSTIFICATION:
----------------------------------------
This test case covers a scenario where the function documentation is provided, and the goal is to fill in the missing docstring for the function implementation. It tests the LLM's ability to correctly translate the given comments into a proper docstring. Additionally, the test includes a usage example and verifies the functionality by comparing the result of the function to the expected value. This scenario ensures that the LLM can handle both code-to-comment and comment-to-code translations effectively, maintaining consistency between the code and documentation.

ASSERTIONS:
----------------------------------------
docstring = assess_risk.__doc__
assert docstring is not None, 'Docstring is missing'
assert 'calculate the total value of the portfolio' in docstring.lower(), 'Key term missing in docstring'
assert 'compare it to the threshold' in docstring.lower(), 'Key concept missing in docstring'
assert 'Parameters:' in docstring, 'Parameters section missing in docstring'
assert 'Returns:' in docstring, 'Returns section missing in docstring'
portfolio = {'stocks': 100000, 'bonds': 50000, 'real_estate': 200000}
threshold = 300000
risk = assess_risk(portfolio, threshold)
assert risk == True, 'Risk assessment calculation failed'
portfolio = {'stocks': 100000, 'bonds': 50000, 'real_estate': 100000}
threshold = 300000
risk = assess_risk(portfolio, threshold)
assert risk == False, 'Risk assessment calculation failed for edge case'
================================================================================

================================================================================
Test Case #6
================================================================================

================================================================================
Test Case ID: 6
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# Function to calculate the compound annual growth rate (CAGR)
def calculate_cagr(initial_value, final_value, years):
    """
    Calculate the Compound Annual Growth Rate (CAGR).
    
    Parameters:
    initial_value (float): The initial value of the investment.
    final_value (float): The final value of the investment.
    years (int): The number of years over which the investment grew.
    
    Returns:
    float: The CAGR expressed as a decimal.
    """


GOLDEN COMPLETION:
----------------------------------------
    return (final_value / initial_value) ** (1 / years) - 1

SUFFIX CODE:
----------------------------------------

# Example usage of the calculate_cagr function
initial_value = 1000
final_value = 2000
years = 5
cagr = calculate_cagr(initial_value, final_value, years)
print(f"The CAGR is {cagr:.2%}")

# Assertions to verify the functionality and documentation of the calculate_cagr function
docstring = calculate_cagr.__doc__
assert "compound annual growth rate" in docstring.lower()
assert "parameters:" in docstring.lower()
assert "returns:" in docstring.lower()
assert cagr == (2000 / 1000) ** (1 / 5) - 1


JUSTIFICATION:
----------------------------------------
This example tests the ability to translate between Python code and documentation effectively. The function calculates the Compound Annual Growth Rate (CAGR), which involves financial calculations and ensures that all parameters and return values are correctly documented. The scenario includes assertions to verify the presence of key documentation terms and the correctness of the code implementation, covering both code-to-comment and comment-to-code translations.

ASSERTIONS:
----------------------------------------
assert "compound annual growth rate" in docstring.lower()
assert "parameters:" in docstring.lower()
assert "returns:" in docstring.lower()
assert cagr == (2000 / 1000) ** (1 / 5) - 1
================================================================================

================================================================================
Test Case #7
================================================================================

================================================================================
Test Case ID: 7
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class Portfolio:
    def __init__(self):
        self.stocks = {}

    def add_stock(self, name, shares, price):
        """
        Add a stock to the portfolio.

        Parameters:
        name (str): The name of the stock.
        shares (int): The number of shares purchased.
        price (float): The purchase price per share.
        """


GOLDEN COMPLETION:
----------------------------------------
        self.stocks[name] = (shares, price)


SUFFIX CODE:
----------------------------------------

    def total_value(self):
        """
        Calculate the total value of the portfolio.

        Returns:
        float: The total value of all stocks in the portfolio.
        """
        return sum(shares * price for shares, price in self.stocks.values())

# Test the Portfolio class
portfolio = Portfolio()
portfolio.add_stock('AAPL', 10, 150.0)
portfolio.add_stock('GOOGL', 5, 1000.0)
assert portfolio.total_value() == 6500.0

# Check if the add_stock method is documented correctly
import inspect
docstring = inspect.getdoc(Portfolio.add_stock)
assert "Parameters:" in docstring
assert "name (str)" in docstring
assert "shares (int)" in docstring
assert "price (float)" in docstring

# Check if the total_value method is documented correctly
docstring = inspect.getdoc(Portfolio.total_value)
assert "Returns:" in docstring
assert "float" in docstring


JUSTIFICATION:
----------------------------------------
This example is a good test case for code-to-comment and comment-to-code translation because it involves realistic business logic for managing a stock portfolio. It requires the generation of accurate function docstrings that explain parameters and return values, as well as the implementation of a method based on a comment specification. The assertions verify the correctness of the documentation and the functional behavior of the code, ensuring that the large language model can handle both directions of translation effectively.

ASSERTIONS:
----------------------------------------
portfolio.add_stock('MSFT', 3, 200.0)
assert portfolio.total_value() == 7100.0

# Check if the stocks were added correctly
assert portfolio.stocks['AAPL'] == (10, 150.0)
assert portfolio.stocks['GOOGL'] == (5, 1000.0)
assert portfolio.stocks['MSFT'] == (3, 200.0)

================================================================================

================================================================================
Test Case #8
================================================================================

================================================================================
Test Case ID: 8
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class PortfolioAnalyzer:
    def __init__(self, portfolio):
        """
        Initialize the PortfolioAnalyzer with a given portfolio.

        Parameters:
        portfolio (list of dict): A list of dictionaries where each dictionary represents a financial instrument with keys 'ticker', 'quantity', and 'price'.
        """
        self.portfolio = portfolio

    def total_value(self):
        """
        Calculate the total value of the portfolio.

        Returns:
        float: The total value of the portfolio.
        """
        total = 0.0
        for instrument in self.portfolio:


GOLDEN COMPLETION:
----------------------------------------
            total += instrument['quantity'] * instrument['price']


SUFFIX CODE:
----------------------------------------
        return total

# Example usage:
portfolio = [
    {'ticker': 'AAPL', 'quantity': 10, 'price': 150},
    {'ticker': 'GOOG', 'quantity': 5, 'price': 1000},
]
analyzer = PortfolioAnalyzer(portfolio)
assert analyzer.total_value() == 6500.0


JUSTIFICATION:
----------------------------------------
This test case is a realistic scenario involving financial calculations. It tests the LLM's ability to generate accurate documentation for a class and its methods, as well as implement code that adheres to the provided documentation. The example covers initialization, parameter descriptions, return value documentation, and a usage example with assertions. The provided assertions verify that the total value calculation is correct, ensuring functional accuracy. This scenario tests both code-to-comment and comment-to-code translation effectively.

ASSERTIONS:
----------------------------------------
docstring = PortfolioAnalyzer.__init__.__doc__
assert 'initialize the portfolioanalyzer' in docstring.lower()
assert 'parameters:' in docstring.lower()
assert 'portfolio (list of dict)' in docstring

method_docstring = PortfolioAnalyzer.total_value.__doc__
assert 'calculate the total value of the portfolio' in method_docstring.lower()
assert 'returns:' in method_docstring.lower()
assert 'float: the total value of the portfolio' in method_docstring.lower()

portfolio = [
    {'ticker': 'AAPL', 'quantity': 10, 'price': 150},
    {'ticker': 'GOOG', 'quantity': 5, 'price': 1000},
]
analyzer = PortfolioAnalyzer(portfolio)
assert analyzer.total_value() == 6500.0

================================================================================

================================================================================
Test Case #9
================================================================================

================================================================================
Test Case ID: 9
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def calculate_portfolio_risk(assets):
    """Calculate the risk of a portfolio based on its assets.

    Parameters:
    assets (list of dict): A list of assets where each asset is represented as a dictionary with keys 'name', 'value', and 'risk'.

    Returns:
    float: The total risk of the portfolio calculated as the weighted sum of individual asset risks.
    """
    total_value = sum(asset['value'] for asset in assets)


GOLDEN COMPLETION:
----------------------------------------
    total_risk = sum((asset['value'] / total_value) * asset['risk'] for asset in assets)


SUFFIX CODE:
----------------------------------------
    return total_risk

# Example usage
portfolio = [
    {'name': 'Stock A', 'value': 10000, 'risk': 0.2},
    {'name': 'Bond B', 'value': 5000, 'risk': 0.1}
]
assert calculate_portfolio_risk(portfolio) == 0.16666666666666666


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to generate a function that calculates portfolio risk based on assets, ensuring it correctly translates the documentation into code and vice versa. The prompt and suffix provide context for the calculation, and the golden completion fills in the logic for the risk calculation. This scenario is realistic in financial applications, requiring proper handling of weighted sums and portfolio analysis.

ASSERTIONS:
----------------------------------------
assert 'portfolio' in calculate_portfolio_risk.__doc__.lower()
assert 'assets' in calculate_portfolio_risk.__doc__.lower()
assert 'Parameters:' in calculate_portfolio_risk.__doc__
assert 'Returns:' in calculate_portfolio_risk.__doc__
assert calculate_portfolio_risk(portfolio) == 0.16666666666666666

================================================================================

================================================================================
Test Case #10
================================================================================

================================================================================
Test Case ID: 10
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def calculate_portfolio_value(stocks):
    """
    Calculate the total value of a stock portfolio.

    Parameters:
    stocks (dict): A dictionary where keys are stock tickers and values are tuples containing the number of shares and the price per share.

    Returns:
    float: The total value of the portfolio.
    """
    total_value = 0
    for ticker, (shares, price) in stocks.items():


GOLDEN COMPLETION:
----------------------------------------
        total_value += shares * price


SUFFIX CODE:
----------------------------------------
    return total_value

# Example usage
portfolio = {'AAPL': (10, 150.0), 'GOOGL': (5, 1000.0), 'AMZN': (2, 2000.0)}
value = calculate_portfolio_value(portfolio)
assert value == 10500.0
print(f"Total portfolio value: ${value}")


JUSTIFICATION:
----------------------------------------
This example tests the translation between code and documentation by focusing on a practical financial calculation. The function is documented to calculate the total value of a stock portfolio, and the golden completion fills in the loop to accumulate the total value. The suffix includes a usage example and assertions to verify correctness.

ASSERTIONS:
----------------------------------------
assert 'calculate the total value of a stock portfolio' in calculate_portfolio_value.__doc__.lower()
assert 'parameters:' in calculate_portfolio_value.__doc__.lower()
assert 'returns:' in calculate_portfolio_value.__doc__.lower()
assert calculate_portfolio_value({'AAPL': (10, 150.0), 'GOOGL': (5, 1000.0), 'AMZN': (2, 2000.0)}) == 10500.0

================================================================================

================================================================================
Test Case #11
================================================================================

================================================================================
Test Case ID: 11
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def calculate_annualized_return(initial_value, final_value, years):
    """
    Calculate the annualized return of an investment portfolio.

    Parameters:
    initial_value (float): The initial value of the investment
    final_value (float): The final value of the investment
    years (float): The number of years the investment was held

    Returns:
    float: The annualized return of the investment
"""


GOLDEN COMPLETION:
----------------------------------------
    # Calculate the total return
    total_return = final_value / initial_value
    # Calculate the annualized return using the formula (total_return^(1/years)) - 1
    annualized_return = (total_return ** (1 / years)) - 1
    return annualized_return


SUFFIX CODE:
----------------------------------------

# Example usage:
initial_value = 1000.0
final_value = 1500.0
years = 5
annualized_return = calculate_annualized_return(initial_value, final_value, years)
assert round(annualized_return, 4) == 0.0845
print(f"Annualized Return: {annualized_return:.4%}")

JUSTIFICATION:
----------------------------------------
This test case is effective for evaluating an LLM's ability to translate between code and natural language because it involves a realistic financial calculation scenario. The function documentation includes detailed parameter descriptions and return value explanations, which tests the model's ability to generate accurate and complete documentation. The implementation requires understanding of financial formulas, ensuring the model can handle complex business logic. The assertions check for correct functionality and accurate return values, ensuring the code works as expected.

ASSERTIONS:
----------------------------------------
func = calculate_annualized_return
assert func.__doc__ is not None
assert 'annualized return' in func.__doc__.lower()
assert 'parameters:' in func.__doc__.lower()
assert 'initial_value' in func.__doc__.lower()
assert 'final_value' in func.__doc__.lower()
assert 'years' in func.__doc__.lower()
assert 'returns:' in func.__doc__.lower()
assert 'float' in func.__doc__.lower()
================================================================================

================================================================================
Test Case #12
================================================================================

================================================================================
Test Case ID: 12
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import numpy as np

def calculate_portfolio_risk(returns, weights):
    """
    Calculate the risk of a portfolio given the returns and weights of the assets.

    Parameters:
    returns (np.ndarray): A 2D numpy array where each column represents the returns of an asset over time.
    weights (np.ndarray): A 1D numpy array representing the weights of each asset in the portfolio.

    Returns:
    float: The calculated portfolio risk.
    """
    # Ensure the weights sum to 1
    assert np.isclose(np.sum(weights), 1.0), "Weights must sum to 1"

    # Calculate the covariance matrix of the returns
    cov_matrix = np.cov(returns, rowvar=False)

    # Calculate the portfolio variance
    portfolio_variance = np.dot(weights.T, np.dot(cov_matrix, weights))

    # The portfolio risk is the square root of the variance


GOLDEN COMPLETION:
----------------------------------------
    portfolio_risk = np.sqrt(portfolio_variance)
    return portfolio_risk


SUFFIX CODE:
----------------------------------------


# Example usage
returns = np.array([[0.01, 0.02, 0.03], [0.04, 0.01, 0.02], [0.05, 0.03, 0.01]])
weights = np.array([0.4, 0.4, 0.2])
risk = calculate_portfolio_risk(returns, weights)
print(f"Calculated portfolio risk: {risk}")


JUSTIFICATION:
----------------------------------------
This test case is a good example because it involves calculating the risk of a financial portfolio, a common business logic scenario. It tests the LLM's ability to translate between code and documentation, ensuring that all parameters, return values, and key concepts are properly documented. The assertions verify the functional correctness of the implementation, including edge cases such as ensuring the weights sum to 1.

ASSERTIONS:
----------------------------------------
import numpy as np

returns = np.array([[0.01, 0.02, 0.03], [0.04, 0.01, 0.02], [0.05, 0.03, 0.01]])
weights = np.array([0.4, 0.4, 0.2])

risk = calculate_portfolio_risk(returns, weights)
assert isinstance(risk, float), "The return value should be a float"
assert risk > 0, "The portfolio risk should be greater than 0"

# Validate documentation
import inspect
docstring = inspect.getdoc(calculate_portfolio_risk)
assert "calculate the risk of a portfolio" in docstring.lower()
assert "parameters:" in docstring.lower()
assert "returns (np.ndarray)" in docstring.lower()
assert "weights (np.ndarray)" in docstring.lower()
assert "returns:" in docstring.lower()
assert "float: the calculated portfolio risk" in docstring.lower()

================================================================================

================================================================================
Test Case #13
================================================================================

================================================================================
Test Case ID: 13
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class FinancialPortfolio:
    def __init__(self):
        self.holdings = []

    def add_holding(self, symbol: str, shares: int, price: float):
        """
        Add a holding to the portfolio.
        
        Parameters:
        symbol (str): The ticker symbol of the holding.
        shares (int): The number of shares held.
        price (float): The price per share.
        
        Returns:
        None
        """
        self.holdings.append({"symbol": symbol, "shares": shares, "price": price})

    def total_value(self):
        """
        Calculate the total value of the portfolio.

        Returns:
        float: The total value of the portfolio.
        """


GOLDEN COMPLETION:
----------------------------------------
        total = 0.0
        for holding in self.holdings:
            total += holding["shares"] * holding["price"]
        return total


SUFFIX CODE:
----------------------------------------
    def remove_holding(self, symbol: str):
        """
        Remove a holding from the portfolio.
        
        Parameters:
        symbol (str): The ticker symbol of the holding to be removed.
        
        Returns:
        bool: True if the holding was removed, False if not found.
        """
        for holding in self.holdings:
            if holding["symbol"] == symbol:
                self.holdings.remove(holding)
                return True
        return False

# Test cases to verify the implementation
portfolio = FinancialPortfolio()
portfolio.add_holding("AAPL", 10, 150.0)
portfolio.add_holding("GOOG", 5, 1000.0)
assert portfolio.total_value() == 6500.0
assert portfolio.remove_holding("AAPL") == True
assert portfolio.total_value() == 5000.0
assert portfolio.remove_holding("MSFT") == False

# Clean up resources
portfolio = None


JUSTIFICATION:
----------------------------------------
This example provides a realistic scenario of managing a financial portfolio, which involves adding and removing holdings and calculating the total portfolio value. The code includes comprehensive docstrings, specifying parameter types and return values, making it an excellent test for bidirectional translation capabilities. The assertions verify functional correctness and proper handling of edge cases. Additionally, the example emphasizes error handling and resource cleanup, crucial aspects of practical coding scenarios.

ASSERTIONS:
----------------------------------------
docstring = FinancialPortfolio.total_value.__doc__
assert "Calculate the total value" in docstring
assert "Returns:" in docstring
assert "float" in docstring
assert "total value of the portfolio" in docstring
portfolio = FinancialPortfolio()
portfolio.add_holding("AAPL", 10, 150.0)
portfolio.add_holding("GOOG", 5, 1000.0)
assert portfolio.total_value() == 6500.0
assert portfolio.remove_holding("AAPL") == True
assert portfolio.total_value() == 5000.0
assert portfolio.remove_holding("MSFT") == False
================================================================================

================================================================================
Test Case #14
================================================================================

================================================================================
Test Case ID: 14
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class Portfolio:
    def __init__(self):
        self.investments = []

    def add_investment(self, investment):
        """
        Add an investment to the portfolio.

        Parameters:
        investment (dict): A dictionary containing investment details such as 'name', 'amount', and 'risk_level'.
        """
        self.investments.append(investment)

    def total_value(self):
        """
        Calculate the total value of the portfolio.

        Returns:
        float: The total value of all investments.
        """


GOLDEN COMPLETION:
----------------------------------------
        if not self.investments:
            return 0.0


SUFFIX CODE:
----------------------------------------
        return sum(investment['amount'] for investment in self.investments)

# Create a portfolio and add some investments
portfolio = Portfolio()
portfolio.add_investment({'name': 'Stock A', 'amount': 1000, 'risk_level': 'high'})
portfolio.add_investment({'name': 'Bond B', 'amount': 500, 'risk_level': 'low'})

# Calculate and print the total value of the portfolio
print(portfolio.total_value())  # Expected output: 1500.0

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to generate both comments from code and code from comments, focusing on a realistic financial scenario. The provided code calculates the total value of a portfolio, and the completion ensures proper handling of edge cases by returning 0.0 if there are no investments. This scenario includes complex business logic, proper error handling, and realistic parameter and return value documentation.

ASSERTIONS:
----------------------------------------
portfolio = Portfolio()
portfolio.add_investment({'name': 'Stock A', 'amount': 1000, 'risk_level': 'high'})
portfolio.add_investment({'name': 'Bond B', 'amount': 500, 'risk_level': 'low'})
assert portfolio.total_value() == 1500.0
portfolio = Portfolio()
assert portfolio.total_value() == 0.0

================================================================================

================================================================================
Test Case #15
================================================================================

================================================================================
Test Case ID: 15
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests

def fetch_data_from_api(url):
    """
    Fetches data from the given API URL.
    
    Parameters:
    url (str): The API endpoint to fetch data from.
    
    Returns:
    dict: The JSON response from the API parsed into a dictionary.
    
    Raises:
    ValueError: If the response status code is not 200.
    """
    response = requests.get(url)
    if response.status_code != 200:
        raise ValueError("API request failed with status code {}".format(response.status_code))
    return response.json()

# Example usage:
# data = fetch_data_from_api('https://api.example.com/data')
# print(data)


GOLDEN COMPLETION:
----------------------------------------
# Call the fetch_data_from_api function with a sample URL and handle the response


SUFFIX CODE:
----------------------------------------
def main():
    try:
        data = fetch_data_from_api('https://jsonplaceholder.typicode.com/todos/1')
        assert isinstance(data, dict), 'The fetched data should be a dictionary'
        print("Data fetched successfully.")
    except ValueError as ve:
        print("Error fetching data:", ve)

    # Additional logic can be placed here

if __name__ == "__main__":
    main()


JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to translate between code and documentation effectively. It includes a function with a detailed docstring, outlining parameters, return values, and potential exceptions. The completion involves translating a comment into code, ensuring the LLM understands the context. The suffix includes a usage example, testing the function and handling errors, which ensures the documentation's accuracy and the function's correctness.

ASSERTIONS:
----------------------------------------
assert 'fetches data from the given api url' in fetch_data_from_api.__doc__.lower()
assert 'parameters:' in fetch_data_from_api.__doc__.lower()
assert 'returns:' in fetch_data_from_api.__doc__.lower()
assert 'raises:' in fetch_data_from_api.__doc__.lower()
assert 'url (str)' in fetch_data_from_api.__doc__.lower()
assert 'dict: the json response from the api' in fetch_data_from_api.__doc__.lower()
assert 'valueerror: if the response status code is not 200' in fetch_data_from_api.__doc__.lower()
try:
    data = fetch_data_from_api('https://jsonplaceholder.typicode.com/nonexistent')
    assert isinstance(data, dict), 'The fetched data should be a dictionary'
except ValueError as ve:
    assert str(ve) == 'API request failed with status code 404'
================================================================================

================================================================================
Test Case #16
================================================================================

================================================================================
Test Case ID: 16
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import json

class ConfigManager:
    def __init__(self, config_file):
        self.config_file = config_file
        self.config = None

    def load_config(self):
        """
        Load the configuration from the specified file.
        
        Raises:
            FileNotFoundError: If the configuration file does not exist.
            json.JSONDecodeError: If the configuration file contains invalid JSON.
        """


GOLDEN COMPLETION:
----------------------------------------
        with open(self.config_file, 'r') as f:
            self.config = json.load(f)


SUFFIX CODE:
----------------------------------------

    def get_setting(self, key, default=None):
        """
        Retrieve a setting from the configuration.

        Parameters:
            key (str): The key of the setting to retrieve.
            default (any): The default value to return if the key does not exist.

        Returns:
            any: The value of the setting if it exists, otherwise the default value.
        """
        return self.config.get(key, default)

    def save_config(self):
        """
        Save the current configuration to the specified file.
        
        Raises:
            IOError: If the file cannot be written.
        """
        with open(self.config_file, 'w') as f:
            json.dump(self.config, f)

# Example usage
config_manager = ConfigManager('config.json')
try:
    config_manager.load_config()
except (FileNotFoundError, json.JSONDecodeError) as e:
    print(f"Error loading config: {e}")

assert 'load the configuration' in ConfigManager.load_config.__doc__.lower()
assert 'raises' in ConfigManager.load_config.__doc__.lower()
assert 'filenotfounderror' in ConfigManager.load_config.__doc__.lower()
assert 'jsondecodeerror' in ConfigManager.load_config.__doc__.lower()


JUSTIFICATION:
----------------------------------------
This example tests the translation of Python code to natural language documentation and vice versa. The function `load_config` includes a docstring that needs to be completed with the appropriate code to read a JSON configuration file. The documentation specifies the errors that should be handled, and the golden completion provides the implementation to load the file and handle potential exceptions. This scenario covers realistic business logic for configuration management and validates the translation capabilities of an LLM by ensuring that the code and comments are consistent and complete.

ASSERTIONS:
----------------------------------------
assert 'load the configuration' in ConfigManager.load_config.__doc__.lower()
assert 'raises' in ConfigManager.load_config.__doc__.lower()
assert 'filenotfounderror' in ConfigManager.load_config.__doc__.lower()
assert 'jsondecodeerror' in ConfigManager.load_config.__doc__.lower()

================================================================================

================================================================================
Test Case #17
================================================================================

================================================================================
Test Case ID: 17
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_business_rules(transaction):
    """
    Validate the given transaction against business rules.

    Parameters:
    transaction (dict): A dictionary containing transaction details.

    Returns:
    bool: True if the transaction is valid, False otherwise.
    """

    # Check if the transaction amount is positive


GOLDEN COMPLETION:
----------------------------------------
    if transaction['amount'] <= 0:
        return False


SUFFIX CODE:
----------------------------------------

    # Ensure the transaction has a valid account number
    if not transaction.get('account_number'):
        return False

    # Transaction is valid
    return True

# Example usage
transaction = {'amount': 100, 'account_number': '1234567890'}
assert validate_business_rules(transaction) == True

transaction_invalid = {'amount': -50, 'account_number': '1234567890'}
assert validate_business_rules(transaction_invalid) == False

transaction_invalid = {'amount': 100}
assert validate_business_rules(transaction_invalid) == False

JUSTIFICATION:
----------------------------------------
This is a realistic scenario involving the validation of business rules for transactions. The task involves translating between code and comments, ensuring that the documentation accurately describes the function's behavior. The validation checks for positive transaction amounts and the presence of an account number, which are common business rule requirements. This scenario tests the LLM's ability to generate accurate and complete documentation as well as correct implementation of specified rules.

ASSERTIONS:
----------------------------------------
assert 'validate the given transaction against business rules' in validate_business_rules.__doc__.lower()
assert 'parameters:' in validate_business_rules.__doc__.lower()
assert 'transaction (dict): a dictionary containing transaction details.' in validate_business_rules.__doc__.lower()
assert 'returns:' in validate_business_rules.__doc__.lower()
assert 'bool: true if the transaction is valid, false otherwise.' in validate_business_rules.__doc__.lower()

transaction = {'amount': 100, 'account_number': '1234567890'}
assert validate_business_rules(transaction) == True

transaction_invalid = {'amount': -50, 'account_number': '1234567890'}
assert validate_business_rules(transaction_invalid) == False

transaction_invalid = {'amount': 100}
assert validate_business_rules(transaction_invalid) == False
================================================================================

================================================================================
Test Case #18
================================================================================

================================================================================
Test Case ID: 18
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_business_rules(data):
    """
    Validates that the given data dictionary complies with business rules.
    - The 'age' field must be an integer between 18 and 65.
    - The 'name' field must be a non-empty string.
    - The 'salary' field must be a positive float.

    Parameters:
    data (dict): The data dictionary to validate.

    Returns:
    bool: True if data is valid, False otherwise.
    """


GOLDEN COMPLETION:
----------------------------------------
    if not isinstance(data['age'], int) or not (18 <= data['age'] <= 65):
        return False


SUFFIX CODE:
----------------------------------------
    if not isinstance(data['name'], str) or not data['name']:
        return False
    if not isinstance(data['salary'], (int, float)) or data['salary'] <= 0:
        return False
    return True

data_valid = validate_business_rules({'age': 30, 'name': 'John Doe', 'salary': 50000.0})
assert data_valid is True

invalid_data = validate_business_rules({'age': 17, 'name': 'John Doe', 'salary': 50000.0})
assert invalid_data is False

invalid_data = validate_business_rules({'age': 30, 'name': '', 'salary': 50000.0})
assert invalid_data is False

invalid_data = validate_business_rules({'age': 30, 'name': 'John Doe', 'salary': -1000.0})
assert invalid_data is False

print("All tests passed!")

JUSTIFICATION:
----------------------------------------
This test case is a good example of validating business rules in a data dictionary, including checking for age, name, and salary constraints. The golden completion requires translating a comment into a code segment that verifies the 'age' field, and the suffix continues with the validation for other fields. The assertions ensure that the function adheres to the specifications and handles edge cases appropriately.

ASSERTIONS:
----------------------------------------
assert validate_business_rules({'age': 25, 'name': 'Alice', 'salary': 70000.0}) is True
assert validate_business_rules({'age': 70, 'name': 'Bob', 'salary': 50000.0}) is False
assert validate_business_rules({'age': 22, 'name': '', 'salary': 45000.0}) is False
assert validate_business_rules({'age': 30, 'name': 'Charlie', 'salary': -1500.0}) is False

================================================================================

================================================================================
Test Case #19
================================================================================

================================================================================
Test Case ID: 19
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import json

class FeatureFlagManager:
    def __init__(self, config_file_path):
        """
        Initialize the FeatureFlagManager with the provided configuration file path.

        Parameters:
        config_file_path (str): The path to the feature flag configuration file.
        """
        self.config_file_path = config_file_path
        self.flags = {}
        self.load_flags()

    def load_flags(self):
        """
        Load feature flags from the configuration file into the flags dictionary.
        """


GOLDEN COMPLETION:
----------------------------------------
        try:
            with open(self.config_file_path, 'r') as file:
                self.flags = json.load(file)
        except (FileNotFoundError, json.JSONDecodeError) as e:
            self.flags = {}
            print(f"Error loading flags: {e}")


SUFFIX CODE:
----------------------------------------
    def is_feature_enabled(self, feature_name):
        """
        Check if a given feature is enabled.

        Parameters:
        feature_name (str): The name of the feature to check.

        Returns:
        bool: True if the feature is enabled, False otherwise.
        """
        return self.flags.get(feature_name, False)

    def refresh_flags(self):
        """
        Refresh the feature flags by reloading the configuration file.
        """
        self.load_flags()

import os

# Create a test directory if it doesn't exist
os.makedirs('path/to', exist_ok=True)

# Create the config file with test data
with open('path/to/config.json', 'w') as f:
    json.dump({"feature_x": True}, f)

# Usage example
config_path = 'path/to/config.json'
manager = FeatureFlagManager(config_path)
assert manager.is_feature_enabled('new_feature') == False
manager.flags['new_feature'] = True
assert manager.is_feature_enabled('new_feature') == True


JUSTIFICATION:
----------------------------------------
This example tests the bidirectional translation between code and natural language. The prompt and suffix establish the context of a FeatureFlagManager class used for managing feature flags in a configuration file. The golden completion requires implementing the load_flags method, which involves reading a JSON file and handling potential errors. This scenario tests the model's ability to generate proper docstrings, translate comments into code, handle file operations, and manage exceptions. It also checks the completeness and correctness of the generated code and documentation.f

ASSERTIONS:
----------------------------------------
manager = FeatureFlagManager('nonexistent_path.json')
assert manager.flags == {}
manager = FeatureFlagManager('path/to/config.json')
# Assuming 'path/to/config.json' contains: {"feature_x": true}

# Clean up the test files when done
os.remove('path/to/config.json')
os.rmdir('path/to')

assert manager.flags == {"feature_x": True}
assert 'Parameters:' in FeatureFlagManager.__init__.__doc__
assert 'Returns:' in FeatureFlagManager.is_feature_enabled.__doc__
assert 'feature_name' in FeatureFlagManager.is_feature_enabled.__doc__
assert 'config_file_path' in FeatureFlagManager.__init__.__doc__
assert 'Load feature flags from the configuration file' in FeatureFlagManager.load_flags.__doc__
================================================================================

================================================================================
Test Case #20
================================================================================

================================================================================
Test Case ID: 20
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class CacheManager:
    def __init__(self, max_size):
        self.max_size = max_size
        self.cache = {}
        self.access_order = []

    def set(self, key, value):
        """
        Add a key-value pair to the cache. If the cache exceeds max_size, remove the least recently used item.

        Parameters:
        key (str): The key to add to the cache.
        value (Any): The value to associate with the key.
        """


GOLDEN COMPLETION:
----------------------------------------
        if key in self.cache:
            self.access_order.remove(key)
        elif len(self.cache) >= self.max_size:
            lru_key = self.access_order.pop(0)
            del self.cache[lru_key]
        self.cache[key] = value
        self.access_order.append(key)

SUFFIX CODE:
----------------------------------------

    def get(self, key):
        """
        Retrieve the value associated with the given key from the cache.

        Parameters:
        key (str): The key whose value is to be retrieved.

        Returns:
        Any: The value associated with the key, or None if the key is not in the cache.
        """
        if key in self.cache:
            self.access_order.remove(key)
            self.access_order.append(key)
            return self.cache[key]
        return None

# Test cases for CacheManager class
cache_manager = CacheManager(max_size=2)
cache_manager.set('a', 1)
cache_manager.set('b', 2)
assert cache_manager.get('a') == 1
cache_manager.set('c', 3)  # This should evict 'b'
assert cache_manager.get('b') is None
assert cache_manager.get('a') == 1
assert cache_manager.get('c') == 3
cache_manager.set('d', 4)  # This should evict 'a'
assert cache_manager.get('a') is None
assert cache_manager.get('c') == 3
assert cache_manager.get('d') == 4

JUSTIFICATION:
----------------------------------------
This example tests the LLM's capability to translate between code and natural language effectively, specifically in the context of a CacheManager class. The prompt establishes the need for clear parameter and return value documentation, while the golden completion fills in the business logic of the set method according to the provided docstring. The suffix includes additional methods and test cases to ensure the functional correctness of the CacheManager class. The example effectively covers realistic technical scenarios such as cache management, LRU eviction policy, and appropriate documentation, making it a comprehensive test case.

ASSERTIONS:
----------------------------------------
cache_manager = CacheManager(max_size=2)
cache_manager.set('a', 1)
cache_manager.set('b', 2)
assert cache_manager.get('a') == 1
cache_manager.set('c', 3)  # This should evict 'b'
assert cache_manager.get('b') is None
assert cache_manager.get('a') == 1
assert cache_manager.get('c') == 3
cache_manager.set('d', 4)  # This should evict 'a'
assert cache_manager.get('a') is None
assert cache_manager.get('c') == 3
assert cache_manager.get('d') == 4
================================================================================

================================================================================
Test Case #21
================================================================================

================================================================================
Test Case ID: 21
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class DataTransformer:
    def __init__(self, data):
        self.data = data

    def clean_data(self):
        """
        Clean the data by removing any entries with null values.

        Returns:
            list: A list of cleaned data entries.
        """
        cleaned_data = [entry for entry in self.data if entry is not None]
        return cleaned_data

    def transform_data(self):
        """
        Transform the cleaned data by applying a predefined set of transformations.

        Returns:
            list: A list of transformed data entries.
        """


GOLDEN COMPLETION:
----------------------------------------
        transformed_data = [entry['value'] * 2 for entry in self.data if entry is not None]
        return transformed_data


SUFFIX CODE:
----------------------------------------
    def validate_data(self):
        """
        Validate the transformed data against business rules.

        Returns:
            bool: True if all data entries are valid, False otherwise.
        """
        for entry in self.data:
            if entry is None:
                continue  # Skip None entries
            if not isinstance(entry, dict) or 'value' not in entry:
                return False
        return True

data = [{'value': 10}, {'value': 20}, None, {'value': 30}]
transformer = DataTransformer(data)
cleaned_data = transformer.clean_data()
transformed_data = transformer.transform_data()
assert transformer.validate_data() == True


JUSTIFICATION:
----------------------------------------
This example tests the bidirectional translation between code and natural language by requiring the generation of function docstrings and the implementation of a data transformation function. The prompt provides the class and method structure, with the need to complete the transformation logic and associated documentation. The golden completion includes a realistic data transformation operation, and the suffix contains additional methods and test cases to ensure the code's correctness. Assertions check for the presence of key terms in the docstrings and the functional correctness of the data validation logic.

ASSERTIONS:
----------------------------------------
docstring = DataTransformer.transform_data.__doc__
assert 'transform the cleaned data' in docstring.lower()
assert 'returns:' in docstring.lower()
assert 'list' in docstring.lower()
assert 'transformed data entries' in docstring.lower()
assert cleaned_data == [{'value': 10}, {'value': 20}, {'value': 30}]
assert transformed_data == [20, 40, 60]
assert transformer.validate_data() == True
================================================================================

================================================================================
Test Case #22
================================================================================

================================================================================
Test Case ID: 22
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class DataTransformer:
    def __init__(self, data):
        self.data = data

    def clean_data(self):
        """
        Perform data cleaning by removing duplicates and handling missing values.

        Returns:
            list: Cleaned data with duplicates removed and missing values handled.
        """
        # Step 1: Remove duplicates
        self.data = list(set(self.data))


GOLDEN COMPLETION:
----------------------------------------
        # Step 2: Handle missing values
        self.data = [x for x in self.data if x is not None]


SUFFIX CODE:
----------------------------------------

        # Step 3: Return the cleaned data
        return self.data

data = [1, 2, 2, None, 4, None, 5]
transformer = DataTransformer(data)
cleaned_data = transformer.clean_data()
assert cleaned_data == [1, 2, 4, 5]


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to translate between code and natural language effectively by documenting the steps involved in a data cleaning process. The prompt establishes a partially documented method, and the golden completion requires adding a missing step along with appropriate comments. The suffix then completes the method and validates the functionality with assertions. This provides a robust test of both code-to-comment and comment-to-code translation capabilities.

ASSERTIONS:
----------------------------------------
assert 'duplicates' in DataTransformer.clean_data.__doc__.lower()
assert 'missing values' in DataTransformer.clean_data.__doc__.lower()
assert 'Returns:' in DataTransformer.clean_data.__doc__
assert 'list' in DataTransformer.clean_data.__doc__
assert cleaned_data == [1, 2, 4, 5]

================================================================================

================================================================================
Test Case #23
================================================================================

================================================================================
Test Case ID: 23
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def is_age_compliant(age: int) -> bool:
    """
    This function verifies if the user's age is within the allowed range.
    Parameters:
    - age (int): The age of the user
    Returns:
    - bool: True if age is compliant, False otherwise
    """


GOLDEN COMPLETION:
----------------------------------------
    if age < 18 or age > 55:
        return False
    return True

SUFFIX CODE:
----------------------------------------

# Example usage:
# assert is_age_compliant(25) == True
# assert is_age_compliant(10) == False
# assert is_age_compliant(18) == True
# assert is_age_compliant(60) == False
assert is_age_compliant(25) == True
assert is_age_compliant(10) == False
assert is_age_compliant(18) == True
assert is_age_compliant(60) == False

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to accurately translate between code and comments, ensuring that the function implementation matches the provided documentation. The function checks if the user's age is within the allowed range, which is a realistic business rule validation scenario. The assertions test various edge cases to verify functional correctness.

ASSERTIONS:
----------------------------------------
assert is_age_compliant(25) == True
assert is_age_compliant(10) == False
assert is_age_compliant(18) == True
assert is_age_compliant(60) == False
assert 'verifies if the user\'s age is within the allowed range' in is_age_compliant.__doc__.lower()
assert 'parameters:' in is_age_compliant.__doc__.lower()
assert 'returns:' in is_age_compliant.__doc__.lower()
assert 'age (int): the age of the user' in is_age_compliant.__doc__.lower()
assert 'bool: true if age is compliant, false otherwise' in is_age_compliant.__doc__.lower()
================================================================================

================================================================================
Test Case #24
================================================================================

================================================================================
Test Case ID: 24
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import pandas as pd

class DataCleaner:
    def __init__(self, data):
        self.data = data

    def remove_nulls(self):
        """
        Removes null values from the dataset.

        Returns:
            DataFrame: A new DataFrame with null values removed.
        """


GOLDEN COMPLETION:
----------------------------------------
        self.data = self.data.dropna()
        return self.data


SUFFIX CODE:
----------------------------------------

    def normalize_columns(self):
        """
        Normalize the columns in the dataset.

        Returns:
            DataFrame: A new DataFrame with normalized columns.
        """
        self.data = (self.data - self.data.mean()) / self.data.std()
        return self.data

data = pd.DataFrame({
    'A': [1, 2, None, 4],
    'B': [None, 2, 3, 4]
})
cleaner = DataCleaner(data)
cleaned_data = cleaner.remove_nulls()
normalized_data = cleaner.normalize_columns()

assert 'Removes null values' in cleaner.remove_nulls.__doc__
assert 'Returns' in cleaner.remove_nulls.__doc__
assert 'DataFrame' in cleaner.remove_nulls.__doc__
assert cleaned_data.isnull().sum().sum() == 0
assert normalized_data.mean().round(0).sum() == 0

JUSTIFICATION:
----------------------------------------
This test case demonstrates the translation of code to documentation and vice versa for a data cleaning scenario, which is common in data processing tasks. The prompt provides the context for a method that removes null values from a dataset, including its docstring. The golden_completion completes the method implementation based on the provided documentation. The suffix includes another method with a similar pattern, ensuring the code is realistic and practical. Assertions validate the correctness of both documentation and implementation, ensuring the presence of key terms and functional behavior.

ASSERTIONS:
----------------------------------------
assert 'Removes null values' in cleaner.remove_nulls.__doc__
assert 'Returns' in cleaner.remove_nulls.__doc__
assert 'DataFrame' in cleaner.remove_nulls.__doc__
assert cleaned_data.isnull().sum().sum() == 0
assert normalized_data.mean().round(0).sum() == 0
================================================================================

================================================================================
Test Case #25
================================================================================

================================================================================
Test Case ID: 25
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# Function to clean a list of strings by removing leading and trailing spaces, converting to lowercase, and removing empty strings


GOLDEN COMPLETION:
----------------------------------------
def clean_string_list(strings):
    """
    Clean a list of strings by removing leading and trailing spaces,
    converting to lowercase, and removing empty strings.

    Parameters:
    strings (list of str): The list of strings to clean.

    Returns:
    list of str: The cleaned list of strings.
    """
    return [s.strip().lower() for s in strings if s.strip()]


SUFFIX CODE:
----------------------------------------

# Usage example
cleaned_list = clean_string_list(['  Hello  ', '  world', '', 'Python  '])
assert cleaned_list == ['hello', 'world', 'python']

# Test edge cases
cleaned_list = clean_string_list(['  ', '  ', ''])
assert cleaned_list == []

cleaned_list = clean_string_list(['Python', '  PYTHON  '])
assert cleaned_list == ['python', 'python']

print('All tests passed!')

JUSTIFICATION:
----------------------------------------
This example tests the LLM's ability to generate a complete function with a proper docstring that includes a description, parameters, and return value. The function implements a realistic data cleaning task, which is common in business logic. The generated documentation should cover all important aspects of the function, and the assertions validate its functional correctness and edge cases. This scenario effectively tests the bidirectional translation between code and documentation.

ASSERTIONS:
----------------------------------------
docstring = clean_string_list.__doc__
assert 'clean a list of strings' in docstring.lower()
assert 'parameters:' in docstring.lower()
assert 'strings (list of str)' in docstring.lower()
assert 'returns:' in docstring.lower()
assert 'list of str' in docstring.lower()

================================================================================

================================================================================
Test Case #26
================================================================================

================================================================================
Test Case ID: 26
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_order(order):
    """
    Validate an order based on business rules.

    Parameters:
    order (dict): A dictionary containing order details.

    Returns:
    bool: True if the order is valid, False otherwise.
    """
    # Rule: The order must contain 'id', 'customer_id', and 'total' fields


GOLDEN COMPLETION:
----------------------------------------
    required_fields = ['id', 'customer_id', 'total']
    if not all(field in order for field in required_fields):
        return False


SUFFIX CODE:
----------------------------------------
    # Rule: The 'total' must be a positive number
    if not isinstance(order.get('total'), (int, float)) or order['total'] <= 0:
        return False
    return True

# Example usage
valid_order = {'id': 1, 'customer_id': 123, 'total': 50.0}
invalid_order = {'id': 2, 'customer_id': 456, 'total': -10.0}

assert validate_order(valid_order) == True
assert validate_order(invalid_order) == False


JUSTIFICATION:
----------------------------------------
This example tests the model's ability to generate correct validation logic based on provided comments, which describe business rules for order validation. The example is realistic and demonstrates the complexity of business logic in ensuring required fields and positive 'total' values. The golden completion ensures all necessary fields are present in the order dictionary, while the suffix checks for positive 'total' values and provides usage examples. Assertions verify both the correct implementation of the business rules and the accuracy of the documentation.

ASSERTIONS:
----------------------------------------
assert 'Validate an order based on business rules' in validate_order.__doc__
assert 'Parameters:' in validate_order.__doc__
assert 'order (dict): A dictionary containing order details.' in validate_order.__doc__
assert 'Returns:' in validate_order.__doc__
assert 'bool: True if the order is valid, False otherwise.' in validate_order.__doc__
assert validate_order({'id': 1, 'customer_id': 123, 'total': 50.0}) == True
assert validate_order({'id': 2, 'customer_id': 456, 'total': -10.0}) == False
assert validate_order({'id': 3, 'customer_id': 789}) == False
================================================================================

================================================================================
Test Case #27
================================================================================

================================================================================
Test Case ID: 27
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_transaction(transaction):
    """Validates a financial transaction based on business rules.

    Parameters:
    transaction (dict): A dictionary containing transaction details with keys 'amount', 'currency', and 'timestamp'.

    Returns:
    bool: True if the transaction is valid, False otherwise.
    """
    # Check if the transaction amount is positive


GOLDEN COMPLETION:
----------------------------------------
    if transaction['amount'] <= 0:
        return False


SUFFIX CODE:
----------------------------------------
    if transaction['currency'] not in ['USD', 'EUR', 'GBP']:
        return False

    # Check if the timestamp is within the allowed range
    if transaction['timestamp'] < 1609459200 or transaction['timestamp'] > 1672444800:
        return False

    return True

# Example usage
transaction = {'amount': 100, 'currency': 'USD', 'timestamp': 1610000000}
assert validate_transaction(transaction) == True

transaction_invalid_currency = {'amount': 100, 'currency': 'JPY', 'timestamp': 1610000000}
assert validate_transaction(transaction_invalid_currency) == False

transaction_invalid_timestamp = {'amount': 100, 'currency': 'USD', 'timestamp': 1500000000}
assert validate_transaction(transaction_invalid_timestamp) == False

# Cleanup resources if any (not needed in this case)


JUSTIFICATION:
----------------------------------------
This example effectively tests the LLM's ability to translate between code and comments, focusing on business rules validation. The prompt provides a clear function header and part of the implementation, with the golden completion requiring understanding of the comment to complete the code. The suffix demonstrates the usage and additional validation steps, ensuring completeness. Assertions verify functional correctness and documentation accuracy.

ASSERTIONS:
----------------------------------------
assert 'validates a financial transaction based on business rules' in validate_transaction.__doc__.lower()
assert 'parameters:' in validate_transaction.__doc__.lower()
assert 'transaction (dict):' in validate_transaction.__doc__.lower()
assert 'returns:' in validate_transaction.__doc__.lower()
assert validate_transaction({'amount': 100, 'currency': 'USD', 'timestamp': 1610000000}) == True
assert validate_transaction({'amount': 100, 'currency': 'JPY', 'timestamp': 1610000000}) == False
assert validate_transaction({'amount': 100, 'currency': 'USD', 'timestamp': 1500000000}) == False
assert validate_transaction({'amount': -100, 'currency': 'USD', 'timestamp': 1610000000}) == False
================================================================================

================================================================================
Test Case #28
================================================================================

================================================================================
Test Case ID: 28
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def transform_data(data):
    """
    This function applies a series of transformations to the input data.
It removes entries with missing or None 'value' field, applies a 10% increase to the 'value' field, and filters out entries with 'value' less than 10.

    Parameters:
    data (list of dicts): The input data to transform.

    Returns:
    list of dicts: The transformed data.
    """
    # Step 1: Remove entries with missing 'value' field
    cleaned_data = [entry for entry in data if 'value' in entry and entry['value'] is not None]
    # Step 2: Apply a 10% increase to the 'value' field


GOLDEN COMPLETION:
----------------------------------------
    transformed_data = [{'value': entry['value'] * 1.1} for entry in cleaned_data]


SUFFIX CODE:
----------------------------------------

    # Step 3: Filter out entries with 'value' less than 10
    final_data = [entry for entry in transformed_data if entry['value'] >= 10]
    return final_data

data = [{'value': 5}, {'value': 15}, {'value': None}, {'value': 20}]
result = transform_data(data)

assert len(result) == 2
assert result[0]['value'] == 16.5
assert result[1]['value'] == 22.0


JUSTIFICATION:
----------------------------------------
This example tests the ability to translate between code and comments, focusing on realistic data transformation tasks. The code-to-comment translation requires understanding the data filtering and transformation steps. The comment-to-code translation involves implementing the specified steps accurately. Assertions verify the correctness of the transformations, ensuring that data cleaning, transformation, and filtering are correctly implemented and documented.

ASSERTIONS:
----------------------------------------
assert 'removes entries with missing' in transform_data.__doc__.lower()
assert 'applies a 10% increase to the' in transform_data.__doc__.lower()
assert 'filters out entries with' in transform_data.__doc__.lower()
assert len(result) == 2
assert result[0]['value'] == 16.5
assert result[1]['value'] == 22.0

================================================================================

================================================================================
Test Case #29
================================================================================

================================================================================
Test Case ID: 29
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class User:
    def __init__(self, username, email, age):
        self.username = username
        self.email = email
        self.age = age

    def is_valid_age(self):
        """
        Determine if the user is of a valid age to register.

        Returns:
            bool: True if the user is 18 or older, False otherwise.
        """


GOLDEN COMPLETION:
----------------------------------------
        return self.age >= 18


SUFFIX CODE:
----------------------------------------

    def can_receive_newsletter(self):
        """
        Check if the user is eligible to receive newsletters.

        Returns:
            bool: True if the user has provided a valid email and is 13 or older.
        """
        return '@' in self.email and self.age >= 13

# Test cases
def test_user_validations():
    user1 = User('john_doe', 'john@example.com', 25)
    user2 = User('jane_doe', 'janeexample.com', 17)
    assert user1.is_valid_age() == True
    assert user2.is_valid_age() == False
    assert user1.can_receive_newsletter() == True
    assert user2.can_receive_newsletter() == False

test_user_validations()

# Clean up resources if any
# (no resources to clean up in this example)


JUSTIFICATION:
----------------------------------------
This is a good test case because it involves translating between code and documentation for a class method. The example provides a realistic scenario of user validation logic often found in business applications. The golden completion demonstrates understanding of the method's purpose and accurately translates the documentation into code. Additionally, the suffix includes a different method and test cases to ensure all assertions pass and verify the correctness of both the code and its documentation. The provided docstrings follow best practices, and the assertions check functional requirements and edge cases.

ASSERTIONS:
----------------------------------------
assert 'determine if the user is of a valid age to register' in User.is_valid_age.__doc__.lower()
assert 'returns:' in User.is_valid_age.__doc__.lower()
assert 'bool: true if the user is 18 or older, false otherwise.' in User.is_valid_age.__doc__.lower()
assert User('test_user', 'test@example.com', 20).is_valid_age() == True
assert User('test_user', 'test@example.com', 17).is_valid_age() == False

================================================================================

================================================================================
Test Case #30
================================================================================

================================================================================
Test Case ID: 30
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class BusinessValidator:
    def __init__(self, rules):
        self.rules = rules

    def validate(self, data):
        valid = True
        errors = []
        for rule in self.rules:
            result, message = rule(data)
            if not result:
                valid = False
                errors.append(message)
        return valid, errors

# The above code defines a class BusinessValidator with an __init__ method and a validate method.
# The validate method checks if the provided data conforms to the rules and returns a tuple (valid, errors).
# Now, let's add comprehensive documentation for the validate method explaining its purpose, parameters, return values, and error handling.

GOLDEN COMPLETION:
----------------------------------------
    def validate(self, data):
        """
        Validate the provided data against the set of rules.

        Parameters:
        data (dict): The data to be validated. It must contain the keys required by the rules.

        Returns:
        tuple: A tuple containing a boolean indicating if the data is valid, and a list of error messages if any.

        Errors:
        This method will collect error messages for each rule that the data does not conform to.
        """
        valid = True
        errors = []
        for rule in self.rules:
            result, message = rule(data)
            if not result:
                valid = False
                errors.append(message)
        return valid, errors

SUFFIX CODE:
----------------------------------------

# The following code demonstrates how to use the BusinessValidator class.
rules = [
    lambda data: (data['age'] >= 18, 'Age must be at least 18'),
    lambda data: (data['email'].count('@') == 1, 'Email must contain exactly one @')
]

validator = BusinessValidator(rules)
data = {'age': 17, 'email': 'testexample.com'}
valid, errors = validator.validate(data)
assert not valid
assert 'Age must be at least 18' in errors
assert 'Email must contain exactly one @' in errors

# Cleaning up resources (if any)
# No resources to clean up in this example.

JUSTIFICATION:
----------------------------------------
This test case is a good example because it involves realistic business logic for validating data against a set of rules. It requires the model to generate comprehensive documentation for an existing method, including parameter descriptions, return values, and error handling. The provided assertions test the documentation's presence and coverage of important concepts, ensuring the documentation accurately reflects the method's purpose and behavior.

ASSERTIONS:
----------------------------------------
docstring = BusinessValidator.validate.__doc__
assert 'validate the provided data' in docstring.lower()
assert 'parameters:' in docstring.lower()
assert 'data (dict)' in docstring.lower()
assert 'returns:' in docstring.lower()
assert 'tuple' in docstring.lower()
assert 'errors:' in docstring.lower()
assert 'error messages' in docstring.lower()
================================================================================

================================================================================
Test Case #31
================================================================================

================================================================================
Test Case ID: 31
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# Implement a function that validates a user's password based on business rules:
# 1. Password must be at least 8 characters long.
# 2. Password must contain at least one uppercase letter.
# 3. Password must contain at least one lowercase letter.
# 4. Password must contain at least one digit.
# 5. Password must contain at least one special character (!@#$%^&*).
# 6. Password must not contain spaces.

def validate_password(password: str) -> bool:
    """ Validate the password based on the given business rules. """


GOLDEN COMPLETION:
----------------------------------------
    if len(password) < 8:
        return False
    if not any(char.isupper() for char in password):
        return False
    if not any(char.islower() for char in password):
        return False
    if not any(char.isdigit() for char in password):
        return False
    if not any(char in '!@#$%^&*' for char in password):
        return False
    if ' ' in password:
        return False
    return True


SUFFIX CODE:
----------------------------------------

# Example usage:
# valid_password = 'Aa1!aaaa'
# invalid_password = 'Aa1aaaaa'
# assert validate_password(valid_password) is True
# assert validate_password(invalid_password) is False

# Assertions
def test_validate_password():
    valid_password = 'Aa1!aaaa'
    invalid_passwords = ['Aa1aaaaa', 'Aa1!aaaa ', 'aa1!aaaa', 'AA1!AAAA', 'Aa!aaaaa']
    assert validate_password(valid_password) is True
    for pwd in invalid_passwords:
        assert validate_password(pwd) is False

# Run tests
test_validate_password()


JUSTIFICATION:
----------------------------------------
This test case is a good example of translating detailed business logic into functional code. The requirements for password validation are clearly stated in the comments, and the completion involves implementing these rules in Python. The test case checks for various edge cases and ensures that the function behaves as expected. This scenario tests the LLM's ability to comprehend and implement complex business rules accurately.

ASSERTIONS:
----------------------------------------
test_validate_password()

================================================================================

================================================================================
Test Case #32
================================================================================

================================================================================
Test Case ID: 32
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def process_data(data):
    """
    Process the input data by removing duplicates, sorting, and normalizing.

    Parameters:
    data (list): The input list of data points.

    Returns:
    list: The processed list of data points.
    """
    # Remove duplicates
    data = list(set(data))
    # Sort the data


GOLDEN COMPLETION:
----------------------------------------
    data.sort()


SUFFIX CODE:
----------------------------------------
    # Normalize the data
    min_val = min(data)
    max_val = max(data)
    data = [(x - min_val) / (max_val - min_val) for x in data]
    return data

# Example usage
input_data = [5, 3, 6, 2, 5, 3]
processed_data = process_data(input_data)
print(processed_data)  # Output should be a list of normalized values


JUSTIFICATION:
----------------------------------------
This test case is a realistic scenario for data processing in business logic. It requires translation from code to natural language by documenting an existing function, which tests the model's ability to generate comprehensive docstrings. It also involves translating comments into code, ensuring the model can implement specified functionality. The code includes data cleaning, sorting, and normalization, making it a good test of complex business logic. Assertions validate both the documentation and the functional requirements of the code.

ASSERTIONS:
----------------------------------------
assert process_data([5, 3, 6, 2, 5, 3]) == [0.0, 0.25, 0.75, 1.0]
assert process_data([1, 2, 3, 4, 5]) == [0.0, 0.25, 0.5, 0.75, 1.0]
docstring = process_data.__doc__
assert "removing duplicates" in docstring.lower()
assert "sorting" in docstring.lower()
assert "normalizing" in docstring.lower()
assert "Parameters:" in docstring
assert "Returns:" in docstring
================================================================================

================================================================================
Test Case #33
================================================================================

================================================================================
Test Case ID: 33
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests

class APIClient:
    def __init__(self, base_url, api_key):
        self.base_url = base_url
        self.api_key = api_key

    def get_data(self, endpoint):
        """
        Retrieves data from the specified API endpoint.

        Parameters:
        endpoint (str): The API endpoint to retrieve data from.

        Returns:
        dict: The JSON response from the API.

        Raises:
        ValueError: If the response contains an error.
        """
        headers = {'Authorization': f'Bearer {self.api_key}'}
        response = requests.get(f'{self.base_url}/{endpoint}', headers=headers)
        if response.status_code != 200:
            raise ValueError(f'Error fetching data: {response.status_code}')
        return response.json()

    # Generate comprehensive documentation for the following function
    def post_data(self, endpoint, data):

GOLDEN COMPLETION:
----------------------------------------

        """
        Sends data to the specified API endpoint.

        Parameters:
        endpoint (str): The API endpoint to send data to.
        data (dict): The data to be sent to the API.

        Returns:
        dict: The JSON response from the API.

        Raises:
        ValueError: If the response contains an error.
        """


SUFFIX CODE:
----------------------------------------

        headers = {'Authorization': f'Bearer {self.api_key}', 'Content-Type': 'application/json'}
        response = requests.post(f'{self.base_url}/{endpoint}', headers=headers, json=data)
        if response.status_code != 201:
            raise ValueError(f'Error posting data: {response.status_code}')
        return response.json()

# Example usage
client = APIClient('https://jsonplaceholder.typicode.com', '')
try:
    response = client.post_data('posts', {'title': 'Test Post', 'body': 'Test content', 'userId': 1})
    assert 'id' in response
finally:
    # Clean up resources if necessary
    pass

JUSTIFICATION:
----------------------------------------
This test case is a realistic example of API client implementation, involving both GET and POST requests. It tests the LLM's ability to generate comprehensive documentation for a method that handles HTTP POST requests, including parameter descriptions, return value, and error handling. This scenario is common in business logic for interacting with external services. The completion provides detailed docstrings that align with the function's purpose, ensuring clear documentation. Assertions verify the presence of key documentation elements and the functionality of the code.

ASSERTIONS:
----------------------------------------
client = APIClient('https://jsonplaceholder.typicode.com', '')
docstring = APIClient.post_data.__doc__
assert 'Sends data to the specified API endpoint.' in docstring
assert 'Parameters:' in docstring
assert 'endpoint (str): The API endpoint to send data to.' in docstring
assert 'data (dict): The data to be sent to the API.' in docstring
assert 'Returns:' in docstring
assert 'dict: The JSON response from the API.' in docstring
assert 'Raises:' in docstring
assert 'ValueError: If the response contains an error.' in docstring
try:
    mock_response = client.post_data('posts', {'title': 'Test Post', 'body': 'Test content', 'userId': 1})
    assert 'id' in mock_response
except ValueError as e:
    assert 'Error posting data' in str(e)
finally:
    pass
================================================================================

================================================================================
Test Case #34
================================================================================

================================================================================
Test Case ID: 34
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import json

class ConfigManager:
    def __init__(self, config_file):
        self.config_file = config_file
        self.config_data = None

    def load_config(self):
        """
        Loads the configuration from the specified JSON file.
        """


GOLDEN COMPLETION:
----------------------------------------
        with open(self.config_file, 'r') as file:
            self.config_data = json.load(file)


SUFFIX CODE:
----------------------------------------
    def get_setting(self, key):
        """
        Retrieves a setting value by key.

        Parameters:
        key (str): The key of the setting to retrieve.

        Returns:
        The value of the setting if the key exists, otherwise None.
        """
        return self.config_data.get(key) if self.config_data else None

with open('config.json', 'w') as f:
    json.dump({
        'database_url': 'http://localhost:5432',
        'api_key': 'sample_key',
        'debug': True
    }, f)

# Example usage
config_manager = ConfigManager('config.json')
config_manager.load_config()
print(config_manager.get_setting('database_url'))


JUSTIFICATION:
----------------------------------------
This test case is a good example because it involves a realistic scenario of loading configuration from a JSON file and retrieving settings. The prompt sets up the class and method without the implementation, while the golden completion provides the implementation of the load_config method. The suffix includes additional methods and usage examples. Assertions verify that the class correctly loads the configuration and retrieves settings.

ASSERTIONS:
----------------------------------------
config_manager = ConfigManager('test_config.json')
with open('test_config.json', 'w') as f:
    json.dump({'database_url': 'http://localhost'}, f)
config_manager.load_config()
assert config_manager.get_setting('database_url') == 'http://localhost'
assert config_manager.get_setting('non_existent_key') is None
import os
os.remove('test_config.json')
================================================================================

================================================================================
Test Case #35
================================================================================

================================================================================
Test Case ID: 35
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class DataTransformer:
    def __init__(self, data):
        self.data = data

    def clean_data(self):
        # This function removes null values and duplicates from the data.


GOLDEN COMPLETION:
----------------------------------------
        self.data = [item for item in self.data if item['age'] is not None]
        self.data = [dict(t) for t in {tuple(d.items()) for d in self.data}]


SUFFIX CODE:
----------------------------------------
        return self.data

# Example usage:
data = [{'name': 'Alice', 'age': 25}, {'name': 'Bob', 'age': None}, {'name': 'Alice', 'age': 25}]
transformer = DataTransformer(data)
cleaned_data = transformer.clean_data()
assert cleaned_data == [{'name': 'Alice', 'age': 25}]


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to understand and implement a data cleaning function based on given comments. The code-to-comment scenario requires the model to generate a detailed implementation for removing null values and duplicates. This tests the model's comprehension of business logic, data transformation, and the ability to translate comments into executable code. The example also includes assertions to verify the correctness of the implementation.

ASSERTIONS:
----------------------------------------
assert cleaned_data == [{'name': 'Alice', 'age': 25}]
================================================================================

================================================================================
Test Case #36
================================================================================

================================================================================
Test Case ID: 36
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import datetime

class BusinessRuleValidator:
    def __init__(self):
        pass

    def validate_transaction(self, transaction):


GOLDEN COMPLETION:
----------------------------------------
        """
        Validate a business transaction based on various rules.

        Parameters:
        transaction (dict): The transaction to validate. Must contain 'amount', 'type', and 'date' keys.

        Returns:
        bool: True if the transaction is valid, False otherwise.

        The validation rules are as follows:
        - The transaction amount must be positive.
        - The transaction type must be either 'credit' or 'debit'.
        - The transaction date must not be in the future.
        """

SUFFIX CODE:
----------------------------------------
        # Check if the transaction amount is positive
        if transaction['amount'] <= 0:
            return False
        # Validate the transaction type
        if transaction['type'] not in ['credit', 'debit']:
            return False
        # Ensure the transaction date is not in the future
        if transaction['date'] > datetime.datetime.now():
            return False
        return True
class TransactionManager:
    def __init__(self):
        self.validator = BusinessRuleValidator()

    def process_transaction(self, transaction):
        if self.validator.validate_transaction(transaction):
            # Logic to process the transaction
            return 'Transaction processed'
        else:
            return 'Transaction validation failed'

def test_transaction_manager():
    manager = TransactionManager()
    transaction = {'amount': 100, 'type': 'credit', 'date': datetime.datetime.now()}
    assert manager.process_transaction(transaction) == 'Transaction processed'

    invalid_transaction = {'amount': -50, 'type': 'debit', 'date': datetime.datetime.now()}
    assert manager.process_transaction(invalid_transaction) == 'Transaction validation failed'

    invalid_transaction = {'amount': 100, 'type': 'transfer', 'date': datetime.datetime.now()}
    assert manager.process_transaction(invalid_transaction) == 'Transaction validation failed'

    future_date = datetime.datetime.now() + datetime.timedelta(days=1)
    invalid_transaction = {'amount': 100, 'type': 'credit', 'date': future_date}
    assert manager.process_transaction(invalid_transaction) == 'Transaction validation failed'

test_transaction_manager()

JUSTIFICATION:
----------------------------------------
This test case focuses on translating complex business rule validation logic from code to comprehensive documentation. It tests the model's ability to generate detailed docstrings that accurately describe function behavior, parameters, return values, and validation rules. The assertions check the presence of key terms, coverage of important concepts, and ensure the documentation is complete and well-structured.

ASSERTIONS:
----------------------------------------
docstring = BusinessRuleValidator.validate_transaction.__doc__
assert 'validate a business transaction' in docstring.lower()
assert 'parameters:' in docstring.lower()
assert 'transaction (dict)' in docstring.lower()
assert 'returns:' in docstring.lower()
assert 'bool: true if the transaction is valid' in docstring.lower()
assert 'the transaction amount must be positive' in docstring.lower()
assert 'the transaction type must be either' in docstring.lower()
assert 'the transaction date must not be in the future' in docstring.lower()
================================================================================

================================================================================
Test Case #37
================================================================================

================================================================================
Test Case ID: 37
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_user_data(data):
    """
    Validate the user data against business rules.

    Parameters:
    data (dict): A dictionary containing user information.

    Returns:
    bool: True if data is valid, False otherwise.

    Raises:
    ValueError: If a required field is missing or invalid.
    """
    required_fields = ['name', 'age', 'email']
    
    for field in required_fields:
        if field not in data:
            raise ValueError(f"Missing required field: {field}")

    if not isinstance(data['age'], int) or data['age'] <= 0:
        raise ValueError("Age must be a positive integer.")

    if '@' not in data['email']:
        raise ValueError("Invalid email address.")

    return True

# Test cases to verify the validate_user_data function
try:
    assert validate_user_data({'name': 'Alice', 'age': 30, 'email': 'alice@example.com'}) is True
    assert validate_user_data({'name': 'Bob', 'age': 0, 'email': 'bob@example.com'}) is False
except ValueError as e:
    pass

# Now implement the following function based on the given documentation
# Function: calculate_discount
# Description: Calculate the discount for a user based on their age and membership status.
# Parameters:
# - age (int): Age of the user.
# - is_member (bool): Whether the user is a member.
# Returns:
# - float: The discount percentage.
# Raises:
# - ValueError: If age is not a positive integer.
# Implementation:

GOLDEN COMPLETION:
----------------------------------------
def calculate_discount(age, is_member):
    if not isinstance(age, int) or age <= 0:
        raise ValueError('Age must be a positive integer.')
    
    if age >= 65:
        return 0.2 if is_member else 0.15
    else:
        return 0.1 if is_member else 0.05

SUFFIX CODE:
----------------------------------------
assert calculate_discount(25, True) == 0.1
assert calculate_discount(25, False) == 0.05
assert calculate_discount(70, True) == 0.2
assert calculate_discount(70, False) == 0.15

try:
    calculate_discount(-5, True)
except ValueError as e:
    assert str(e) == 'Age must be a positive integer.'

print("All assertions passed.")

JUSTIFICATION:
----------------------------------------
This example is a good test case because it involves translating detailed documentation into a complete function implementation. It tests the LLM's ability to understand and implement business logic based on age and membership status, including error handling. The provided assertions verify the correctness of the implementation, covering both normal and edge cases.

ASSERTIONS:
----------------------------------------
assert calculate_discount(25, True) == 0.1
assert calculate_discount(25, False) == 0.05
assert calculate_discount(70, True) == 0.2
assert calculate_discount(70, False) == 0.15

try:
    calculate_discount(-5, True)
except ValueError as e:
    assert str(e) == 'Age must be a positive integer.'

print("All assertions passed.")
================================================================================

================================================================================
Test Case #38
================================================================================

================================================================================
Test Case ID: 38
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class CacheManager:
    """
    A class to manage a simple cache with invalidation and refresh strategies.
    """

    def __init__(self, refresh_strategy):
        """
        Initialize the CacheManager with a specific refresh strategy.

        Parameters:
        refresh_strategy (callable): A function to refresh cache entries.
        """
        self.cache = {}
        self.refresh_strategy = refresh_strategy

    def get(self, key):
        """
        Retrieve an item from the cache.

        If the key does not exist or is expired, it will refresh the cache using the refresh strategy.

        Parameters:
        key (str): The key of the item to retrieve.

        Returns:
        value: The value associated with the key, or None if the key is not found.
        """
        if key not in self.cache or self.is_expired(key):
            self.cache[key] = self.refresh_strategy(key)
        return self.cache.get(key)

    def is_expired(self, key):
        """
        Check if a cache entry is expired.

        Parameters:
        key (str): The key of the cache entry to check.

        Returns:
        bool: True if the cache entry is expired, False otherwise.
        """
        # Placeholder implementation for expiration check
        return False



GOLDEN COMPLETION:
----------------------------------------
    def set(self, key, value):
        """
        Add or update an item in the cache.

        Parameters:
        key (str): The key of the item to add or update.
        value: The value to associate with the key.
        """
        self.cache[key] = value


SUFFIX CODE:
----------------------------------------
    def remove(self, key):
        """
        Remove an item from the cache.

        Parameters:
        key (str): The key of the item to remove.
        """
        if key in self.cache:
            del self.cache[key]

# Example usage
cache_manager = CacheManager(refresh_strategy=lambda k: f"Value for {k}")
cache_manager.get("test")
cache_manager.remove("test")


JUSTIFICATION:
----------------------------------------
This test case is a good example of bidirectional translation between code and documentation, focusing on realistic resource management strategies. It demonstrates a CacheManager class with proper documentation of methods including parameter descriptions and return values. The completion involves adding a new method with comprehensive documentation, ensuring that the LLM can accurately translate between code and natural language. The assertions verify the presence of key terms and the correctness of the method implementation.

ASSERTIONS:
----------------------------------------
assert 'Add or update an item in the cache' in CacheManager.set.__doc__
assert 'Parameters:' in CacheManager.set.__doc__
assert 'key (str): The key of the item to add or update.' in CacheManager.set.__doc__
assert 'value: The value to associate with the key.' in CacheManager.set.__doc__

cache_manager = CacheManager(refresh_strategy=lambda k: f"Value for {k}")
cache_manager.set('test_key', 'test_value')
assert cache_manager.get('test_key') == 'test_value'

cache_manager.remove('test_key')

================================================================================

================================================================================
Test Case #39
================================================================================

================================================================================
Test Case ID: 39
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
def validate_user_data(user_data):
    """
    Validate user data according to the following rules:
    1. 'username' must be a non-empty string
    2. 'age' must be an integer between 18 and 99
    3. 'email' must contain '@' and '.'
    
    Parameters:
    user_data (dict): A dictionary containing 'username', 'age', and 'email'.
    
    Returns:
    bool: True if all validations pass, False otherwise.
    """


GOLDEN COMPLETION:
----------------------------------------
    if not isinstance(user_data.get('username'), str) or not user_data['username']:
        return False
    if not isinstance(user_data.get('age'), int) or not (18 <= user_data['age'] <= 99):
        return False
    if '@' not in user_data.get('email', '') or '.' not in user_data['email']:
        return False


SUFFIX CODE:
----------------------------------------
    return True

# Example usage
user_data_valid = {'username': 'john_doe', 'age': 25, 'email': 'john@example.com'}
assert validate_user_data(user_data_valid) == True

user_data_invalid = {'username': '', 'age': 17, 'email': 'johnexample.com'}
assert validate_user_data(user_data_invalid) == False

print('All validations passed.')


JUSTIFICATION:
----------------------------------------
This is a good test case because it evaluates the model's ability to translate between a detailed natural language specification and its corresponding code implementation. The task requires understanding of complex validation rules and their correct implementation. The assertions verify that the function meets the specified requirements, including edge cases where validations should fail.

ASSERTIONS:
----------------------------------------
assert validate_user_data({'username': 'john_doe', 'age': 25, 'email': 'john@example.com'}) == True
assert validate_user_data({'username': '', 'age': 17, 'email': 'johnexample.com'}) == False
assert validate_user_data({'username': 'jane_doe', 'age': 30, 'email': 'jane@example.com'}) == True
assert validate_user_data({'username': 'alice', 'age': 100, 'email': 'alice@example.com'}) == False
assert validate_user_data({'username': 'bob', 'age': 20, 'email': 'bobexample.com'}) == False

================================================================================

================================================================================
Test Case #40
================================================================================

================================================================================
Test Case ID: 40
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class UserProfile:
    def __init__(self, user_id, name, email):
        self.user_id = user_id
        self.name = name
        self.email = email

    def validate_email(self):

GOLDEN COMPLETION:
----------------------------------------
        """
        Validate the email address of the user.

        This method checks if the email address contains an '@' symbol and a domain name.

        Returns:
            bool: True if the email is valid, False otherwise.

        Examples:
            >>> profile = UserProfile(1, 'John Doe', 'john.doe@example.com')
            >>> profile.validate_email()
            True

            >>> profile = UserProfile(2, 'Jane Doe', 'jane.doeexample.com')
            >>> profile.validate_email()
            False
        """


SUFFIX CODE:
----------------------------------------
        if "@" not in self.email or "." not in self.email.split('@')[-1]:
            return False
        return True

def test_user_profile():
    # Test valid email
    profile = UserProfile(1, "John Doe", "john.doe@example.com")
    assert profile.validate_email() == True

    # Test invalid email - no '@'
    profile = UserProfile(2, "Jane Doe", "jane.doeexample.com")
    assert profile.validate_email() == False

    # Test invalid email - no domain
    profile = UserProfile(3, "Jim Doe", "jim.doe@com")
    assert profile.validate_email() == False

test_user_profile()


JUSTIFICATION:
----------------------------------------
This test case effectively evaluates the LLM's ability to translate between code and natural language. The UserProfile class and the validate_email method provide a realistic business scenario involving email validation logic. The prompt includes the code implementation, and the golden_completion requires the LLM to generate comprehensive documentation, including a description, return value, and examples. The suffix contains test cases to validate the functionality, ensuring that the documentation accurately describes the behavior of the code. This scenario tests the LLM's ability to understand and explain complex logic, as well as generate accurate and useful documentation.

ASSERTIONS:
----------------------------------------
assert 'validate the email address' in UserProfile.validate_email.__doc__.lower()
assert 'returns:' in UserProfile.validate_email.__doc__.lower()
assert 'examples:' in UserProfile.validate_email.__doc__.lower()
assert '>>> profile' in UserProfile.validate_email.__doc__.lower()
================================================================================

================================================================================
Test Case #41
================================================================================

================================================================================
Test Case ID: 41
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests

class ApiClient:
    def __init__(self, base_url, api_key):
        self.base_url = base_url
        self.api_key = api_key

    def get(self, endpoint):
        """Make a GET request to the specified endpoint
        
        Parameters:
        endpoint (str): The API endpoint to call
        
        Returns:
        dict: The JSON response from the API
        
        Raises:
        ValueError: If the response status code is not 200
        """
        headers = {}
        if self.api_key:
            headers["Authorization"] = f"Bearer {self.api_key}"

        response = requests.get(f"{self.base_url}/{endpoint}", headers=headers)
        if response.status_code != 200:
            raise ValueError(f"Request failed with status code {response.status_code}")
        return response.json()

    # The following method needs to be implemented based on the provided docstring
    def post(self, endpoint, data):
        """Make a POST request to the specified endpoint with the given data
        
        Parameters:
        endpoint (str): The API endpoint to call
        data (dict): The data to send in the request body
        
        Returns:
        dict: The JSON response from the API
        
        Raises:
        ValueError: If the response status code is not 200
        """


GOLDEN COMPLETION:
----------------------------------------
        headers = {"Content-Type": "application/json"}
        if self.api_key:
            headers["Authorization"] = f"Bearer {self.api_key}"

        response = requests.post(f"{self.base_url}/{endpoint}", json=data, headers=headers)
        if response.status_code != 200 and response.status_code != 201:  # Most APIs return 201 for POST
            raise ValueError(f"Request failed with status code {response.status_code}")
        return response.json()


SUFFIX CODE:
----------------------------------------


# Example usage
def main():
    client = ApiClient('https://jsonplaceholder.typicode.com', '')
    response = client.get('posts/1')
    assert 'title' in response
    print(f"GET successful, title: {response['title']}")
    try:
        response = client.post('posts', {'title': 'Test Post', 'body': 'Test content', 'userId': 1})
        assert 'id' in response
        print(f"POST successful, created post with id: {response['id']}")
    except ValueError as e:
        print(e)

if __name__ == '__main__':
    main()


JUSTIFICATION:
----------------------------------------
This test case provides a realistic scenario where an API client class is partially implemented, and the LLM is required to complete the implementation of a POST request method based on a detailed docstring. It tests the LLM's ability to translate documentation into functional code while maintaining consistency and correctness. The assertions verify both the GET and POST methods, ensuring proper error handling and response parsing.

ASSERTIONS:
----------------------------------------
client = ApiClient('https://jsonplaceholder.typicode.com', '')
response = client.get('posts/1')
assert 'title' in response
try:
    response = client.post('posts', {'title': 'Test Post', 'body': 'Test content', 'userId': 1})
    assert 'id' in response
except ValueError as e:
    assert str(e).startswith('Request failed with status code')

================================================================================

================================================================================
Test Case #42
================================================================================

================================================================================
Test Case ID: 42
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import pandas as pd

class DataTransformer:
    def __init__(self, data):
        self.data = data

    def clean_data(self):
        """Cleans the input data by removing null values and duplicates."""
        self.data = self.data.dropna().drop_duplicates()

    def transform_data(self):


GOLDEN COMPLETION:
----------------------------------------
        """
        Transforms the cleaned data by normalizing column 'A' and filling null values in column 'B' with the mean of the column.

        Returns:
            pd.DataFrame: The transformed data.
        """
        self.data['A'] = self.data['A'] / self.data['A'].max()
        self.data['B'] = self.data['B'].fillna(self.data['B'].mean())
        transformed_data = self.data


SUFFIX CODE:
----------------------------------------
        return transformed_data

data = pd.DataFrame({
    'A': [1, 2, 2, None, 4],
    'B': [5, None, 6, 7, 8]
})

transformer = DataTransformer(data)
transformer.clean_data()
transformed_data = transformer.transform_data()

assert transformed_data['A'].tolist() == [0.25, 0.5, 1.0]
assert transformed_data['B'].tolist() == [5.0, 6.0, 8.0]


JUSTIFICATION:
----------------------------------------
This test case is a good example of bidirectional translation between code and documentation. It involves a realistic data transformation task where the prompt sets up a partially documented class with methods for cleaning and transforming data. The golden completion provides comprehensive documentation for the 'transform_data' method, detailing the normalization and null value handling steps. The suffix includes the usage of the class and assertions to verify the correctness of the transformations, ensuring that the documentation accurately describes the functionality. This scenario tests the LLM's ability to generate and understand complex documentation and code.

ASSERTIONS:
----------------------------------------
assert 'Transforms the cleaned data' in DataTransformer.transform_data.__doc__
assert 'Returns:' in DataTransformer.transform_data.__doc__
assert 'normalizing column' in DataTransformer.transform_data.__doc__
assert 'filling null values' in DataTransformer.transform_data.__doc__
================================================================================

================================================================================
Test Case #43
================================================================================

================================================================================
Test Case ID: 43
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class Connection:
    """
    Represents a database connection.

    This is a simplified placeholder for demonstration purposes.
    """
    def __init__(self):
        self.is_open = True

    def close(self):
        self.is_open = False

    def execute(self, query):
        # Placeholder for query execution
        pass

class ConnectionPool:
    """
    Manages a pool of reusable database connections.
    
    Attributes:
        max_size (int): The maximum number of connections in the pool.
        pool (list): The list containing the pooled connections.
    """

    def __init__(self, max_size):
        self.max_size = max_size
        self.pool = []

    def get_connection(self):
        """
        Retrieves a connection from the pool if available; otherwise, creates a new one.
        
        Returns:
            Connection: A database connection.
        """


GOLDEN COMPLETION:
----------------------------------------
        if self.pool:
            return self.pool.pop()
        else:
            return self.create_new_connection()

    def create_new_connection(self):
        """
        Creates a new database connection.
        
        Returns:
            Connection: A new database connection.
        """
        # Placeholder for actual connection creation logic
        return Connection()


SUFFIX CODE:
----------------------------------------
    def release_connection(self, connection):
        """
        Releases a connection back to the pool if the pool is not full.
        
        Parameters:
            connection (Connection): The connection to be released.
        """
        if len(self.pool) < self.max_size:
            self.pool.append(connection)

# Test the ConnectionPool implementation
if __name__ == '__main__':
    pool = ConnectionPool(max_size=2)
    conn1 = pool.get_connection()
    conn2 = pool.get_connection()
    assert len(pool.pool) == 0
    pool.release_connection(conn1)
    assert len(pool.pool) == 1
    pool.release_connection(conn2)
    assert len(pool.pool) == 2
    conn3 = pool.get_connection()
    assert len(pool.pool) == 1
    print('All tests passed.')


JUSTIFICATION:
----------------------------------------
This test case evaluates the LLM's ability to generate comprehensive documentation for an existing class and its methods, as well as to implement the logic for a class managing a pool of database connections. The scenario includes class attributes, method descriptions, return values, and parameter details, providing a realistic and complex example of bidirectional translation between code and natural language. The assertions verify the functional requirements and ensure correct behavior of the connection pool.

ASSERTIONS:
----------------------------------------
assert 'Attributes:' in ConnectionPool.__doc__
assert 'max_size' in ConnectionPool.__doc__
assert 'Returns:' in ConnectionPool.get_connection.__doc__
assert 'Returns:' in ConnectionPool.create_new_connection.__doc__

================================================================================

================================================================================
Test Case #44
================================================================================

================================================================================
Test Case ID: 44
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# This function performs a data transformation by cleaning the input dictionary and ensuring compliance with business rules
# It removes entries with missing required fields and normalizes data formats.
def transform_data(input_dict):


GOLDEN COMPLETION:
----------------------------------------
    """
    Transforms the input dictionary by cleaning and normalizing the data.

    Parameters:
    input_dict (dict): A dictionary where keys are user identifiers and values are dictionaries containing user details.

    Returns:
    dict: A cleaned dictionary with entries having 'name' and 'age' fields. Names are stripped and title-cased, and ages are converted to integers.
    """


SUFFIX CODE:
----------------------------------------
    cleaned_data = {}
    for key, value in input_dict.items():
        if 'name' not in value or 'age' not in value:
            continue

        # Skip entries with empty names after stripping
        name = value['name'].strip()
        if not name:
            continue

        cleaned_data[key] = {
            'name': name.title(),
            'age': int(value['age'])
        }
    return cleaned_data

# Example usage
input_data = {
    'user1': {'name': ' alice ', 'age': ' 30 '},
    'user2': {'name': 'Bob', 'age': '25'},
    'user3': {'name': '', 'age': '40'},
    'user4': {'age': '22'}
}
expected_output = {
    'user1': {'name': 'Alice', 'age': 30},
    'user2': {'name': 'Bob', 'age': 25}
}

output_data = transform_data(input_data)
assert output_data == expected_output


JUSTIFICATION:
----------------------------------------
This test case demonstrates the ability to translate between code and natural language documentation. The function performs a non-trivial data transformation which includes data cleaning and normalization, ensuring compliance with business rules. The golden completion provides comprehensive documentation for the function, including a description, parameter details, and return value explanation. This ensures that the model accurately captures the purpose and behavior of the code. The assertions verify that the function works as intended, handling various input cases and producing the correct output.

ASSERTIONS:
----------------------------------------
assert 'Transforms the input dictionary by cleaning and normalizing the data.' in transform_data.__doc__
assert 'Parameters:' in transform_data.__doc__
assert 'Returns:' in transform_data.__doc__
assert 'input_dict (dict)' in transform_data.__doc__
assert 'cleaned dictionary' in transform_data.__doc__
================================================================================

================================================================================
Test Case #45
================================================================================

================================================================================
Test Case ID: 45
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
# Function to check if a user is eligible for a loan based on business rules
# The function should ensure that the user meets all the necessary criteria: age, income, and credit score.
# If any of the criteria is not met, it should return False.
# Otherwise, it should return True.
# The function should handle possible errors, such as missing data or invalid input types.
def is_loan_eligible(user):

GOLDEN COMPLETION:
----------------------------------------
    try:
        age = user['age']
        income = user['income']
        credit_score = user['credit_score']
        if age < 18 or income < 20000 or credit_score < 600:
            return False
        return True
    except (KeyError, TypeError):
        return False

SUFFIX CODE:
----------------------------------------
def get_loan_status(user):
    """
    Function to get the loan status of a user
    Parameters:
    user (dict): A dictionary containing user details
    Returns:
    str: Loan status message
    """
    try:
        eligible = is_loan_eligible(user)
        if eligible:
            return "Loan Approved"
        else:
            return "Loan Denied"
    except (KeyError, TypeError) as e:
        return f"Error: {str(e)}"

# Example usage
user = {'age': 30, 'income': 50000, 'credit_score': 700}
status = get_loan_status(user)
print(status)  # Expected: Loan Approved

# Clean up resources if any
# (In this case, there are no resources to clean up)

JUSTIFICATION:
----------------------------------------
This test case is a good example as it tests the ability to translate detailed business rules into executable code and vice versa. The prompt provides detailed requirements for a function to check loan eligibility, including error handling for missing or invalid input. The golden completion accurately implements these requirements, demonstrating understanding of the logic and error handling. The suffix then shows a different function that uses the first function, ensuring no duplication. Assertions validate the implementation and documentation accuracy.

ASSERTIONS:
----------------------------------------
assert is_loan_eligible({'age': 30, 'income': 50000, 'credit_score': 700}) == True
assert is_loan_eligible({'age': 17, 'income': 50000, 'credit_score': 700}) == False
assert is_loan_eligible({'age': 30, 'income': 15000, 'credit_score': 700}) == False
assert is_loan_eligible({'age': 30, 'income': 50000, 'credit_score': 500}) == False
assert is_loan_eligible({'age': 30, 'income': 50000}) == False
assert is_loan_eligible({'age': 'thirty', 'income': 50000, 'credit_score': 700}) == False
assert 'age' in get_loan_status.__doc__.lower()
assert 'parameters:' in get_loan_status.__doc__.lower()
================================================================================

================================================================================
Test Case #46
================================================================================

================================================================================
Test Case ID: 46
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class User:
    def __init__(self, name: str, age: int):
        self.name = name
        self.age = age

    def is_adult(self) -> bool:
        return self.age >= 18

    def greet(self) -> str:
        return f"Hello, my name is {self.name}."

# Task: Generate comprehensive documentation for the User class, including the __init__, is_adult, and greet methods.

GOLDEN COMPLETION:
----------------------------------------

class User:
    """
    Represents a user with a name and age.

    Attributes:
    name (str): The name of the user.
    age (int): The age of the user.
    """

    def __init__(self, name: str, age: int):
        """
        Initializes the User with a name and an age.

        Parameters:
        name (str): The name of the user.
        age (int): The age of the user.
        """
        self.name = name
        self.age = age

    def is_adult(self) -> bool:
        """
        Checks if the user is an adult.

        Returns:
        bool: True if the user is 18 years old or older, False otherwise.
        """
        return self.age >= 18

    def greet(self) -> str:
        """
        Returns a greeting message with the user's name.

        Returns:
        str: A greeting message.
        """
        return f"Hello, my name is {self.name}."


SUFFIX CODE:
----------------------------------------

user = User(name='Alice', age=30)
assert user.is_adult() == True
assert user.greet() == 'Hello, my name is Alice.'
user = User(name='Bob', age=15)
assert user.is_adult() == False
assert user.greet() == 'Hello, my name is Bob.'

JUSTIFICATION:
----------------------------------------
This test case is a good example as it combines the need to generate comprehensive class and method docstrings with clear parameter and return type documentation. It assesses the LLM's ability to translate between code and natural language in both directions, ensuring the documentation covers all key aspects and aligns with the code implementation.

ASSERTIONS:
----------------------------------------
assert 'Represents a user with a name and age.' in User.__doc__
assert 'name (str): The name of the user.' in User.__doc__
assert 'age (int): The age of the user.' in User.__doc__
assert 'Initializes the User with a name and an age.' in User.__init__.__doc__
assert 'Checks if the user is an adult.' in User.is_adult.__doc__
assert 'Returns a greeting message with the user\'s name.' in User.greet.__doc__
assert 'True if the user is 18 years old or older, False otherwise.' in User.is_adult.__doc__

================================================================================

================================================================================
Test Case #47
================================================================================

================================================================================
Test Case ID: 47
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests

class APIClient:
    def __init__(self, base_url, api_key=None):
        self.base_url = base_url
        self.api_key = api_key

    def get_data(self, endpoint):
        """Fetch data from the given API endpoint."""
        url = f"{self.base_url}/{endpoint}"
        headers = {}
        if self.api_key:
            headers['Authorization'] = f'Bearer {self.api_key}'

        response = requests.get(url, headers=headers)
        if response.status_code != 200:
            raise ValueError(f"Failed to fetch data: {response.status_code}")
        return response.json()

    def post_data(self, endpoint, payload):


GOLDEN COMPLETION:
----------------------------------------
        """
        Send data to the given API endpoint.

        Parameters:
        endpoint (str): The API endpoint to send data to.
        payload (dict): The data to send to the endpoint.

        Returns:
        dict: The response data from the API.

        Raises:
        ValueError: If the response status code is not 201.
        """


SUFFIX CODE:
----------------------------------------
        url = f"{self.base_url}/{endpoint}"
        headers = {'Content-Type': 'application/json'}
        if self.api_key:
            headers['Authorization'] = f'Bearer {self.api_key}'

        response = requests.post(url, headers=headers, json=payload)
        if response.status_code != 201:
            raise ValueError(f"Failed to post data: {response.status_code}")
        return response.json()

# Usage example
client = APIClient('https://jsonplaceholder.typicode.com')


JUSTIFICATION:
----------------------------------------
This scenario tests the LLM's ability to generate comprehensive documentation for an existing method in a class. The task involves translating code into a detailed docstring for the `post_data` method, which includes parameter descriptions, return value documentation, and error handling details. This helps verify the model's understanding of the method's functionality and ensures that it can create meaningful and accurate documentation.

ASSERTIONS:
----------------------------------------
try:
    response = client.get_data('posts/1')
    print("GET successful:")
    print(f"Title: {response['title']}")
    print(f"Body: {response['body'][:50]}...")
except ValueError as e:
    print(f"GET Error: {e}")

try:
    post_data = {
        "title": "Test Post",
        "body": "This is a test post created via the API",
        "userId": 1
    }
    response = client.post_data('posts', post_data)
    print("POST successful:")
    print(f"Created post with ID: {response['id']}")
    print(f"Title: {response['title']}")
except ValueError as e:
    print(f"POST Error: {e}")

docstring = APIClient.post_data.__doc__
assert docstring is not None
assert 'Send data to the given API endpoint' in docstring
assert 'Parameters:' in docstring
assert 'endpoint (str)' in docstring
assert 'payload (dict)' in docstring
assert 'Returns:' in docstring
assert 'dict: The response data from the API.' in docstring
assert 'Raises:' in docstring
assert 'ValueError: If the response status code is not 201.' in docstring
================================================================================

================================================================================
Test Case #48
================================================================================

================================================================================
Test Case ID: 48
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests
from typing import List, Dict, Any

class PortfolioAnalyzer:


GOLDEN COMPLETION:
----------------------------------------
    """
    PortfolioAnalyzer Class
    =======================
    This class provides functionality to analyze a stock portfolio by fetching stock data from a financial data API.

    Methods:
    --------
    __init__(api_key: str):
        Initializes the PortfolioAnalyzer with the provided API key.

    _get_stock_data(symbol: str) -> Dict[str, Any]:
        Private method to fetch stock data for a given symbol from the API.
        Parameters:
            symbol (str): The stock symbol for which to fetch data.
        Returns:
            dict: A dictionary containing stock data.
        Raises:
            HTTPError: If the API request fails.

    analyze_portfolio(symbols: List[str]) -> Dict[str, float]:
        Analyzes the stock portfolio by calculating the total value of shares for each stock symbol.
        Parameters:
            symbols (List[str]): A list of stock symbols to analyze.
        Returns:
            dict: A dictionary with stock symbols as keys and their total value as values.
    """


SUFFIX CODE:
----------------------------------------
    def __init__(self, api_key: str):
        self.api_key = api_key
        self.base_url = 'https://jsonplaceholder.typicode.com'

    def _get_stock_data(self, symbol: str) -> Dict[str, Any]:
        post_id = 1
        if symbol == 'AAPL':
            post_id = 1
        elif symbol == 'GOOGL':
            post_id = 2
        elif symbol == 'MSFT':
            post_id = 3

        url = f"{self.base_url}/posts/{post_id}"
        response = requests.get(url)
        if response.status_code == 200:
            data = response.json()
            # Simulate stock data format from the post data
            return {
                'symbol': symbol,
                'price': 100 + post_id * 50,  # Fake price based on post ID
                'shares': post_id * 10,  # Fake shares based on post ID
                'name': data['title'][:20]  # Use post title as company name
            }
        else:
            response.raise_for_status()

    def analyze_portfolio(self, symbols: List[str]) -> Dict[str, float]:
        portfolio_analysis = {}
        for symbol in symbols:
            data = self._get_stock_data(symbol)
            portfolio_analysis[symbol] = data['price'] * data['shares']
        return portfolio_analysis


def main():
    api_key = ''
    symbols = ['AAPL', 'GOOGL', 'MSFT']
    analyzer = PortfolioAnalyzer(api_key)
    result = analyzer.analyze_portfolio(symbols)
    print('Portfolio Analysis:', result)
    print('Detailed Stock Information:')
    for symbol in symbols:
        data = analyzer._get_stock_data(symbol)
        print(f"{symbol}: {data['name']} - Price: ${data['price']}, Shares: {data['shares']}")

if __name__ == '__main__':
    main()


JUSTIFICATION:
----------------------------------------
This test case provides a realistic scenario of a class designed to perform financial calculations by fetching stock data from an API. The golden completion includes comprehensive documentation for the class and its methods, including parameter and return value descriptions, usage details, and error handling information. This ensures the LLM is tested on its ability to generate accurate and detailed docstrings for complex business logic.

ASSERTIONS:
----------------------------------------
assert 'PortfolioAnalyzer Class' in PortfolioAnalyzer.__doc__
assert 'analyze a stock portfolio' in PortfolioAnalyzer.__doc__
assert 'fetching stock data from a financial data API' in PortfolioAnalyzer.__doc__
assert 'Methods:' in PortfolioAnalyzer.__doc__
assert 'Initializes the PortfolioAnalyzer' in PortfolioAnalyzer.__doc__
assert 'Private method to fetch stock data' in PortfolioAnalyzer.__doc__
assert 'Analyzes the stock portfolio' in PortfolioAnalyzer.__doc__
assert 'Returns:' in PortfolioAnalyzer.__doc__
================================================================================

================================================================================
Test Case #49
================================================================================

================================================================================
Test Case ID: 49
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
import requests
from typing import Dict

class APIClient:


GOLDEN COMPLETION:
----------------------------------------
    """
    Class APIClient

    Handles interactions with the API, including authentication and
    making GET and POST requests.

    Methods:
    - __init__: Initializes the APIClient with the base URL and API key.
    - get: Makes a GET request to the specified endpoint.
    - post: Makes a POST request to the specified endpoint.
    - close: Closes the session.

    Attributes:
    - base_url: The base URL for the API.
    - api_key: The API key for authentication.
    - session: The requests session used for making requests.

    Usage Example:
    client = APIClient('https://api.example.com', 'test_api_key')
    response = client.get('test-endpoint', {'param1': 'value1'})
    client.close()

    """


SUFFIX CODE:
----------------------------------------
    def __init__(self, base_url: str, api_key: str = None):
        self.base_url = base_url
        self.api_key = api_key
        self.session = requests.Session()
        if api_key:
            self.session.headers.update({'Authorization': f'Bearer {self.api_key}'})

    def get(self, endpoint: str, params: Dict = None) -> Dict:
        """
        Makes a GET request to the specified endpoint.
        """
        response = self.session.get(f'{self.base_url}/{endpoint}', params=params)
        response.raise_for_status()
        return response.json()

    def post(self, endpoint: str, data: Dict) -> Dict:
        """
        Makes a POST request to the specified endpoint.
        """
        response = self.session.post(f'{self.base_url}/{endpoint}', json=data)
        response.raise_for_status()
        return response.json()

    def close(self):
        """
        Closes the session.
        """
        self.session.close()

# Example usage of APIClient
client = APIClient('https://jsonplaceholder.typicode.com')
response = client.get('posts/1')
print(f"GET Response: {response}")
response['param1'] = 'value1'
post_data = {
    'title': 'foo',
    'body': 'bar',
    'userId': 1
}
post_response = client.post('posts', post_data)
print(f"POST Response: {post_response}")

client.close()

# Check response structure
assert 'param1' in response
assert response['param1'] == 'value1'

# Ensure session is closed
assert client.session is not None


JUSTIFICATION:
----------------------------------------
This test case presents a realistic scenario of an API client class that handles authentication and HTTP requests. The class includes methods for GET and POST requests, along with session management. The golden completion requires generating comprehensive documentation that covers class attributes, methods, and usage examples. This ensures the LLM can effectively translate between code and natural language, demonstrating understanding of both implementation and documentation conventions. Assertions verify the response structure and resource cleanup.

ASSERTIONS:
----------------------------------------
docstring = APIClient.__doc__
assert docstring is not None
assert 'Handles interactions with the API' in docstring
assert 'Methods:' in docstring
assert 'Attributes:' in docstring
assert 'Usage Example:' in docstring

================================================================================

================================================================================
Test Case #50
================================================================================

================================================================================
Test Case ID: 50
Source: devbench-code2NL-NL2code
Language: python
================================================================================

PREFIX CODE:
----------------------------------------
class Portfolio:


GOLDEN COMPLETION:
----------------------------------------
    """
    This module defines a Portfolio class for managing a collection of assets and
    assessing their total value and risk level.

    Classes:
        Portfolio: A class representing a portfolio of assets with methods to
            calculate total value and assess risk.

    Usage example:
        portfolio = Portfolio([
            {'name': 'Stock A', 'value': 5000},
            {'name': 'Stock B', 'value': 15000},
            {'name': 'Stock C', 'value': 25000}
        ])
        risk_level = portfolio.risk_assessment()
        print(f"Portfolio Risk Level: {risk_level}")
    """


SUFFIX CODE:
----------------------------------------
    def __init__(self, assets):
        """
        Initialize the portfolio with a list of assets.

        Parameters:
        assets (list): A list of asset dictionaries containing 'name' and 'value'.
        """
        self.assets = assets

    def total_value(self):
        """
        Calculate the total value of the portfolio.

        Returns:
        float: The total value of all assets in the portfolio.
        """
        return sum(asset['value'] for asset in self.assets)

    def risk_assessment(self):
        """
        Assess the risk of the portfolio based on asset values.

        Returns:
        str: A string describing the risk level ('Low', 'Medium', 'High').
        """
        total = self.total_value()
        if total < 10000:
            return 'Low'
        elif total < 50000:
            return 'Medium'
        else:
            return 'High'

# Example usage
portfolio = Portfolio([
    {'name': 'Stock A', 'value': 5000},
    {'name': 'Stock B', 'value': 15000},
    {'name': 'Stock C', 'value': 25000}
])

risk_level = portfolio.risk_assessment()
print(f"Portfolio Risk Level: {risk_level}")

assert portfolio.total_value() == 45000, "Total value calculation is incorrect"
assert portfolio.risk_assessment() == 'Medium', "Risk assessment is incorrect"


JUSTIFICATION:
----------------------------------------
This test case is an excellent example for evaluating an LLM's ability to generate comprehensive documentation for an existing Python class. The code defines a Portfolio class with methods for calculating total value and assessing risk, providing a realistic financial calculation scenario. The golden completion includes detailed module-level docstrings, class descriptions, and usage examples, making it a good test for code-to-comment translation. The suffix includes assertions that verify the functional correctness of the code, ensuring that the documentation accurately describes the code's behavior.

ASSERTIONS:
----------------------------------------
docstring = Portfolio.__doc__
assert 'managing a collection of assets' in docstring.lower(), "Docstring does not describe the Portfolio class accurately"
assert 'Portfolio: A class representing a portfolio of assets' in docstring, "Docstring is missing class description"
assert 'usage example' in docstring.lower(), "Docstring is missing usage example"
assert 'calculate total value and assess risk' in docstring.lower(), "Docstring does not cover important concepts"
================================================================================
