Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

moved README.md to src/ #3

Merged
merged 1 commit into from
Jan 9, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
113 changes: 0 additions & 113 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,114 +1 @@
# Learn Rust with Tests

⚠️ **WIP**: **This project is an ongoing work in progress. Links may be broken and content may be missing. If you find something wrong, please open an issue and we'll get them fixed asap.**

## Why

* Explore the Rust language by writing tests
* **Get a grounding with TDD**. Rust is a great language for learning TDD because it is a simple language to learn and testing is built-in
* Be confident that you'll be able to start writing robust, well-tested systems in Rust
* [Watch a video, or read about why unit testing and TDD is important](why.md)

## Table of contents

### Rust fundamentals

1. [Install Rust](src/install_rust.md) - Set up environment for productivity.
2. [Hello, world](src/hello_world.md) - Declaring variables, constants, if/else statements, loops, functions, write your first Rust program and write your first test. Sub-test syntax and closures.
3. [Primitives](src/primitives.md) - Further Explore function declaration syntax and learn new ways to improve the documentation of your code.
4. [Control Flow](src/control_flow.md) - Declaring if/else, loops, match, to control the flow of your program.
4. [Vectors](src/vectors.md) - Learn about one of the most used data structures.
5. [Ownership and Borrow Checker](src/ownership_borrow_checker.md) - Learn about ownership, borrowing, and lifetimes.
6. [Structs](src/structs.md) - Learn about the three struct types: a classic C struct, a tuple struct, and a unit struct..
7. [Enums](src/enums.md) - Learn about how to define and use `enums`.
8. [Strings](src/strings.md) - Learn about the two string types, a string slice (&str) and an owned string (String).
9. [Modules](src/modules.md) - Learn how to use the module system.
10. [Mocking](src/mocking.md) - Learn how to use the `Mockall` library to mocking.
11. [Hashmaps](src/hashmaps.md) - Learn how to define and use `hashmaps`.
12. [Options](src/options.md) - Learn how every Option is either Some and contains a value, or None, and does not.
13. [Error Handling](src/error_handling.md) - Learn how to properly handle errors.
14. [Generics](src/generics.md) - Learn how `generics` generalize types and functionalities to broader cases, reducing code duplication.
15. [Traits](src/traits.md) - Learn how `traits` define shared behaviors.
16. [Lifetimes](src/lifetimes.md) - Learn how lifetimes tell the compiler how to check whether references live long enough to be valid in any given situation
17. [Iterators](src/iterators.md) - Learn about the different ways to iterate.
18. [Smart Pointers](src/smart_pointers.md) - Learn about how smart pointers are variables that contain an address in memory and reference some other data.
19. [Threads](src/threads.md) - Learn about how programs can have independent parts that run simultaneously.
20. [Macros](macros.md) - Learn how to use and create `macros`.
21. [Conversions](conversions.md) - Learn about the many ways to convert a value of a given type into another type.

### Build an application

Now that you have hopefully digested the _Rust Fundamentals_ section you have a solid grounding of a majority of Rust's language features and how to do TDD.

This next section will involve building an application.

Each chapter will iterate on the previous one, expanding the application's functionality as our product owner dictates.

New concepts will be introduced to help facilitate writing great code but most of the new material will be learning what can be accomplished from Rust's standard library.

By the end of this, you should have a strong grasp as to how to iteratively write an application in Rust, backed by tests.

* [HTTP server](http-server.md) - We will create an application which listens to HTTP requests and responds to them.
* [JSON, routing and embedding](json.md) - We will make our endpoints return JSON and explore how to do routing.
* [IO and sorting](io.md) - We will persist and read our data from disk and we'll cover sorting data.
* [Command line & project structure](command-line.md) - Support multiple applications from one code base and read input from command line.
* [Time](time.md) - using the `time` package to schedule activities.
* [WebSockets](websockets.md) - learn how to write and test a server that uses WebSockets.

### Testing fundamentals

Covering other subjects around testing.

* [Introduction to acceptance tests](intro-to-acceptance-tests.md) - Learn how to write acceptance tests for your code, with a real-world example for gracefully shutting down a HTTP server
* [Scaling acceptance tests](scaling-acceptance-tests.md) - Learn techniques to manage the complexity of writing acceptance tests for non-trivial systems.
* [Working without mocks, stubs and spies](working-without-mocks.md) - Learn about how to use fakes and contracts to create more realistic and maintainable tests.
* [Refactoring Checklist](refactoring-checklist.md) - Some discussion on what refactoring is, and some basic tips on how to do it.

### Questions and answers

I often run in to questions on the internets like

> How do I test my amazing function that does x, y and z

If you have such a question raise it as an issue on github and I'll try and find time to write a short chapter to tackle the issue. I feel like content like this is valuable as it is tackling people's _real_ questions around testing.

* [OS exec](os-exec.md) - An example of how we can reach out to the OS to execute commands to fetch data and keep our business logic testable/
* [Error types](error-types.md) - Example of creating your own error types to improve your tests and make your code easier to work with.
* [Revisiting HTTP Handlers](http-handlers-revisited.md) - Testing HTTP handlers seems to be the bane of many a developer's existence. This chapter explores the issues around designing handlers correctly.

### Meta / Discussion

* [Why unit tests and how to make them work for you](why.md) - Watch a video, or read about why unit testing and TDD is important
* [Anti-patterns](anti-patterns.md) - A short chapter on TDD and unit testing anti-patterns

## Contributing

* _This project is work in progress_ If you would like to contribute, please do get in touch.
* Read [contributing.md](https://github.com/quii/learn-Rust-with-tests/tree/842f4f24d1f1c20ba3bb23cbc376c7ca6f7ca79a/contributing.md) for guidelines
* Any ideas? Create an issue

## Who this is for

* People who are interested in picking up Rust.
* People who already know some Rust, but want to explore testing with TDD.

## What you'll need

* A computer!
* [Installed Rust](https://rust-lang.org/)
* A text editor
* Some experience with programming. Understanding of concepts like `if`, variables, functions etc.
* Comfortable using the terminal

## Support me

I am proud to offer this resource for free, but if you wish to give some appreciation:

- [Tweet me @0xglitchbyte](https://twitter.com/0xglitchbyte)

## Feedback

* Add issues/submit PRs [here](https://github.com/0xGlitchbyte/learn_Rust_with_tests) or [tweet me @0xglitchbyte](https://twitter.com/0xglitchbyte)

[MIT license](LICENSE.md)

101 changes: 0 additions & 101 deletions index.html
Original file line number Diff line number Diff line change
@@ -145,107 +145,6 @@ <h1 class="menu-title">Learn Rust with Tests</h1>
<div id="content" class="content">
<main>
<h1 id="learn-rust-with-tests"><a class="header" href="#learn-rust-with-tests">Learn Rust with Tests</a></h1>
<p>⚠️ <strong>WIP</strong>: <strong>This project is an ongoing work in progress. Links may be broken and content may be missing. If you find something wrong, please open an issue and we'll get them fixed asap.</strong></p>
<h2 id="why"><a class="header" href="#why">Why</a></h2>
<ul>
<li>Explore the Rust language by writing tests</li>
<li><strong>Get a grounding with TDD</strong>. Rust is a great language for learning TDD because it is a simple language to learn and testing is built-in</li>
<li>Be confident that you'll be able to start writing robust, well-tested systems in Rust</li>
<li><a href="why.html">Watch a video, or read about why unit testing and TDD is important</a></li>
</ul>
<h2 id="table-of-contents"><a class="header" href="#table-of-contents">Table of contents</a></h2>
<h3 id="rust-fundamentals"><a class="header" href="#rust-fundamentals">Rust fundamentals</a></h3>
<ol>
<li><a href="src/install_rust.html">Install Rust</a> - Set up environment for productivity.</li>
<li><a href="src/hello_world.html">Hello, world</a> - Declaring variables, constants, if/else statements, loops, functions, write your first Rust program and write your first test. Sub-test syntax and closures.</li>
<li><a href="src/primitives.html">Primitives</a> - Further Explore function declaration syntax and learn new ways to improve the documentation of your code.</li>
<li><a href="src/control_flow.html">Control Flow</a> - Declaring if/else, loops, match, to control the flow of your program.</li>
<li><a href="src/vectors.html">Vectors</a> - Learn about one of the most used data structures.</li>
<li><a href="src/ownership_borrow_checker.html">Ownership and Borrow Checker</a> - Learn about ownership, borrowing, and lifetimes.</li>
<li><a href="src/structs.html">Structs</a> - Learn about the three struct types: a classic C struct, a tuple struct, and a unit struct..</li>
<li><a href="src/enums.html">Enums</a> - Learn about how to define and use <code>enums</code>.</li>
<li><a href="src/strings.html">Strings</a> - Learn about the two string types, a string slice (&amp;str) and an owned string (String).</li>
<li><a href="src/modules.html">Modules</a> - Learn how to use the module system.</li>
<li><a href="src/mocking.html">Mocking</a> - Learn how to use the <code>Mockall</code> library to mocking.</li>
<li><a href="src/hashmaps.html">Hashmaps</a> - Learn how to define and use <code>hashmaps</code>.</li>
<li><a href="src/options.html">Options</a> - Learn how every Option is either Some and contains a value, or None, and does not.</li>
<li><a href="src/error_handling.html">Error Handling</a> - Learn how to properly handle errors.</li>
<li><a href="src/generics.html">Generics</a> - Learn how <code>generics</code> generalize types and functionalities to broader cases, reducing code duplication.</li>
<li><a href="src/traits.html">Traits</a> - Learn how <code>traits</code> define shared behaviors.</li>
<li><a href="src/lifetimes.html">Lifetimes</a> - Learn how lifetimes tell the compiler how to check whether references live long enough to be valid in any given situation</li>
<li><a href="src/iterators.html">Iterators</a> - Learn about the different ways to iterate.</li>
<li><a href="src/smart_pointers.html">Smart Pointers</a> - Learn about how smart pointers are variables that contain an address in memory and reference some other data.</li>
<li><a href="src/threads.html">Threads</a> - Learn about how programs can have independent parts that run simultaneously.</li>
<li><a href="macros.html">Macros</a> - Learn how to use and create <code>macros</code>.</li>
<li><a href="conversions.html">Conversions</a> - Learn about the many ways to convert a value of a given type into another type.</li>
</ol>
<h3 id="build-an-application"><a class="header" href="#build-an-application">Build an application</a></h3>
<p>Now that you have hopefully digested the <em>Rust Fundamentals</em> section you have a solid grounding of a majority of Rust's language features and how to do TDD.</p>
<p>This next section will involve building an application.</p>
<p>Each chapter will iterate on the previous one, expanding the application's functionality as our product owner dictates.</p>
<p>New concepts will be introduced to help facilitate writing great code but most of the new material will be learning what can be accomplished from Rust's standard library.</p>
<p>By the end of this, you should have a strong grasp as to how to iteratively write an application in Rust, backed by tests.</p>
<ul>
<li><a href="http-server.html">HTTP server</a> - We will create an application which listens to HTTP requests and responds to them.</li>
<li><a href="json.html">JSON, routing and embedding</a> - We will make our endpoints return JSON and explore how to do routing.</li>
<li><a href="io.html">IO and sorting</a> - We will persist and read our data from disk and we'll cover sorting data.</li>
<li><a href="command-line.html">Command line &amp; project structure</a> - Support multiple applications from one code base and read input from command line.</li>
<li><a href="time.html">Time</a> - using the <code>time</code> package to schedule activities.</li>
<li><a href="websockets.html">WebSockets</a> - learn how to write and test a server that uses WebSockets.</li>
</ul>
<h3 id="testing-fundamentals"><a class="header" href="#testing-fundamentals">Testing fundamentals</a></h3>
<p>Covering other subjects around testing.</p>
<ul>
<li><a href="intro-to-acceptance-tests.html">Introduction to acceptance tests</a> - Learn how to write acceptance tests for your code, with a real-world example for gracefully shutting down a HTTP server</li>
<li><a href="scaling-acceptance-tests.html">Scaling acceptance tests</a> - Learn techniques to manage the complexity of writing acceptance tests for non-trivial systems.</li>
<li><a href="working-without-mocks.html">Working without mocks, stubs and spies</a> - Learn about how to use fakes and contracts to create more realistic and maintainable tests.</li>
<li><a href="refactoring-checklist.html">Refactoring Checklist</a> - Some discussion on what refactoring is, and some basic tips on how to do it.</li>
</ul>
<h3 id="questions-and-answers"><a class="header" href="#questions-and-answers">Questions and answers</a></h3>
<p>I often run in to questions on the internets like</p>
<blockquote>
<p>How do I test my amazing function that does x, y and z</p>
</blockquote>
<p>If you have such a question raise it as an issue on github and I'll try and find time to write a short chapter to tackle the issue. I feel like content like this is valuable as it is tackling people's <em>real</em> questions around testing.</p>
<ul>
<li><a href="os-exec.html">OS exec</a> - An example of how we can reach out to the OS to execute commands to fetch data and keep our business logic testable/</li>
<li><a href="error-types.html">Error types</a> - Example of creating your own error types to improve your tests and make your code easier to work with.</li>
<li><a href="http-handlers-revisited.html">Revisiting HTTP Handlers</a> - Testing HTTP handlers seems to be the bane of many a developer's existence. This chapter explores the issues around designing handlers correctly.</li>
</ul>
<h3 id="meta--discussion"><a class="header" href="#meta--discussion">Meta / Discussion</a></h3>
<ul>
<li><a href="why.html">Why unit tests and how to make them work for you</a> - Watch a video, or read about why unit testing and TDD is important</li>
<li><a href="anti-patterns.html">Anti-patterns</a> - A short chapter on TDD and unit testing anti-patterns</li>
</ul>
<h2 id="contributing"><a class="header" href="#contributing">Contributing</a></h2>
<ul>
<li><em>This project is work in progress</em> If you would like to contribute, please do get in touch.</li>
<li>Read <a href="https://github.com/quii/learn-Rust-with-tests/tree/842f4f24d1f1c20ba3bb23cbc376c7ca6f7ca79a/contributing.md">contributing.md</a> for guidelines</li>
<li>Any ideas? Create an issue</li>
</ul>
<h2 id="who-this-is-for"><a class="header" href="#who-this-is-for">Who this is for</a></h2>
<ul>
<li>People who are interested in picking up Rust.</li>
<li>People who already know some Rust, but want to explore testing with TDD.</li>
</ul>
<h2 id="what-youll-need"><a class="header" href="#what-youll-need">What you'll need</a></h2>
<ul>
<li>A computer!</li>
<li><a href="https://rust-lang.org/">Installed Rust</a></li>
<li>A text editor</li>
<li>Some experience with programming. Understanding of concepts like <code>if</code>, variables, functions etc.</li>
<li>Comfortable using the terminal</li>
</ul>
<h2 id="support-me"><a class="header" href="#support-me">Support me</a></h2>
<p>I am proud to offer this resource for free, but if you wish to give some appreciation:</p>
<ul>
<li><a href="https://twitter.com/0xglitchbyte">Tweet me @0xglitchbyte</a></li>
</ul>
<h2 id="feedback"><a class="header" href="#feedback">Feedback</a></h2>
<ul>
<li>Add issues/submit PRs <a href="https://github.com/0xGlitchbyte/learn_Rust_with_tests">here</a> or <a href="https://twitter.com/0xglitchbyte">tweet me @0xglitchbyte</a></li>
</ul>
<p><a href="LICENSE.html">MIT license</a></p>

</main>

Loading