Skip to content

StefRuseva88/restapi-github-tests

Repository files navigation

Rest API GitHub Tests

C# .NET GitHub REST API RestSharp NUnit

This is a test project for Back-End Test Automation March 2024 Course @ SoftUni


Project Description

This project is designed to test various functionalities of the GitHub API using RestSharp and NUnit. The purpose is to automate the testing of RESTful web services to ensure they work correctly and handle errors gracefully.

Technologies Used

  • RestSharp: A powerful library to simplify HTTP requests in .NET.
  • NUnit: A popular unit testing framework for .NET applications.

GitHub API Endpoints

  • GitHub Issues provides the standard RESTful API endpoints, which you can access with HTTP client from GitHub API edndpoints
  • This project tests various endpoints of the GitHub API.
  • For a full list of available endpoints, refer to the GitHub API documentation

GitHub API Project

  • RestSharpServices: Methods that interact with the GitHub API using RestSharp.
  • TestGitHubApi: Tests to verify the functionality of the RestSharpServices methods.
  • Models: These classes represent the data that the GitHub API will send and receive.

Setting Up the RestSharp Client

The constructor takes three parameters:

  • BaseUrl: The root URL of the GitHub API. This is where all API requests will start from.
  • Username: Your GitHub username.
  • Token: Your GitHub personal access token. This is used for authentication and allows you to interact with the GitHub API.

Implementing API Methods and Tests

Incremental Approach: To use this apprach you have to write one method, then immediately write the corresponding test to validate it. Then Repeat this process for each method. This approach helps to focus on one piece of functionality at a time and makes debugging easier.

License

This project is licensed under the MIT License. See the LICENSE file for details.

Contact

For any questions or suggestions, please reach out to me or open an issue in the repository.


Happy Testing! 🚀

Releases

No releases published

Packages

No packages published

Languages