Basit Bir Test Framework Geliştirelim 10

2023-05-11

Genellikle bir test framework’ünde “Parameterized Tests” veya “Data-Driven Tests” adı verilen bir özellik kullanılır. Bu özellik, bir test metodunun farklı veri setleriyle birden çok kez çalıştırılmasını sağlar. Bizde bu özelliği ekleyelim.

Aşağıda, TestCase adında bir attribute ve TestRunner‘da bu attribute’u işleyecek kodu tanımlayalım, bu sayede TestRunner ıda refactor edelim.

using System;
using System.Reflection;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

// ...

public class TestCaseAttribute : Attribute
{
    public object[] Parameters { get; }

    public TestCaseAttribute(params object[] parameters)
    {
        Parameters = parameters;
    }
}

public static class TestRunner
{
    public static async Task RunTestsAsync<T>()
    {
        var testClassInstance = Activator.CreateInstance<T>();

        var testMethods = typeof(T)
            .GetMethods()
            .Where(m => m.GetCustomAttributes<TestAttribute>().Any())
            .ToList();

        foreach (var testMethod in testMethods)
        {
            var testCaseAttributes = testMethod.GetCustomAttributes<TestCaseAttribute>();

            if (!testCaseAttributes.Any())
            {
                await RunTestMethodAsync(testClassInstance, testMethod);
            }
            else
            {
                foreach (var testCase in testCaseAttributes)
                {
                    await RunTestMethodAsync(testClassInstance, testMethod, testCase.Parameters);
                }
            }
        }
    }

    private static async Task RunTestMethodAsync<T>(T testClassInstance, MethodInfo testMethod, object[] parameters = null)
	{
    	try
    	{
        	// Test metodunu çalıştır ve sonucu bekler
        	if (parameters == null)
        	{
            	await (Task)testMethod.Invoke(testClassInstance, null);
        	}
        	else
        	{
            	await (Task)testMethod.Invoke(testClassInstance, parameters);
        	}

        	// Test başarılı oldu
        	Console.ForegroundColor = ConsoleColor.Green;
        	Console.WriteLine($"{testMethod.Name} PASSED");
    	}
    	catch (Exception ex)
    	{
        	// Test bir hata nedeniyle başarısız oldu
        	Console.ForegroundColor = ConsoleColor.Red;
        	Console.WriteLine($"{testMethod.Name} FAILED");

        	// Exception, bir AssertFailedException ise, hata mesajını yazdır
        	if (ex.InnerException is AssertFailedException assertFailedException)
        	{
            	Console.WriteLine(assertFailedException.Message);
        	}
        	else
        	{
            	// Diğer hataları da yazdır
            	Console.WriteLine(ex.InnerException);
        	}
    	}
    	finally
    	{
        	// Konsol rengini normal rengine döndür
        	Console.ResetColor();
    	}
	}
 	

}

Bu kod, TestRunner‘ın test metotlarını bulurken TestCaseAttribute‘ları aramasını ve bulduğu her bir TestCaseAttribute için test metodunu çalıştırmasını sağlar. Her bir TestCaseAttribute‘un parametreleri, test metoduna argüman olarak verilir. Bu sayede, bir test metodunu farklı parametrelerle birden çok kez çalıştırabilirsiniz.



Bu gibi daha fazla gönderi...

SemaphoreSlim Sınıfı: C#'ta Çoklu Görevlere Dayalı Programlama

2023-06-10 | #net #semaphoreslim

Genel Bakış SemaphoreSlim sınıfı, bir veya daha fazla threadin aynı anda belirli bir kaynağı veya işlemi kullanmasını kontrol etmek için C# ‘ta kullanılan bir yapıdır. SemaphoreSlim, aynı anda kaynağa erişebilecek thread sayısını sınırlar. SemaphoreSlim kullanımı, genellikle çok threadli uygulamalarda deadlock durumlarını önlemek ve belirli bir kaynağın aynı anda yalnızca bir veya daha fazla thread tarafından kullanılmasını sağlamak için kullanılır. SemaphoreSlim Kullanımı SemaphoreSlim sınıfı, aşağıdaki gibi kullanılır: SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1, 1); Burada ilk parametre, aynı anda kaç threadin kaynağı kullanabileceğini belirler.

Devamı 


Basit Bir Rest Api Client Geliştirelim 9

2023-05-14 | #diy-rest-api-client #do-it-yourself #net #rest-api

HTTP isteklerini izlemek ve teşhis etmek için daha fazla yetenek ekleyerek, kütüphanemizi daha da geliştirebiliriz. Bu amaçla, isteklerin ve yanıtların bazı temel bilgilerini loga kaydeden bir middleware ekleyelim. Bu özellik, HTTP isteklerinin ve yanıtlarının kaydını tutmak için HttpClient‘in DelegatingHandler sınıfını kullanır. Bu, bir HTTP isteği gönderildiğinde ve bir yanıt alındığında çalışan bir kod parçasıdır. Bu durumda, HTTP isteklerinin ve yanıtlarının bazı temel bilgilerini loga kaydeder. Aşağıda, bu özelliği eklemek için gereken kod parçacığı bulunmaktadır:

Devamı 


Basit Bir Rest Api Client Geliştirelim 8

2023-05-12 | #diy-rest-api-client #do-it-yourself #net #rest-api

Bu noktada, geliştirmemiz gereken bir diğer önemli konu da güvenlikle ilgili olabilir. Özellikle, API çağrıları genellikle belirli bir kimlik doğrulama yöntemi gerektirir. Bunu sağlamak için, HTTP istemcimizi çok kullanılan iki kimlik doğrulama yöntemiyle, yani Basic Authentication ve Bearer (Token) Authentication ile uyumlu hale getirebiliriz. Bu amaçla, istemcimize iki yeni metot ekleyelim: public void SetBasicAuthentication(string username, string password) { var basicAuthValue = Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}")); SetDefaultHeader("Authorization", $"Basic {basicAuthValue}"); } public void SetBearerToken(string token) { SetDefaultHeader("Authorization", $"Bearer {token}"); } Bu metodlar, Authorization başlığını ayarlar, böylece her HTTP talebi kimlik doğrulama bilgilerini içerir.

Devamı 