-
Notifications
You must be signed in to change notification settings - Fork 10.4k
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
Stdio, Read, Write and Files #482
Comments
I can try and take files if that would be okay! |
I'd like to help close this. What kinds of exercises would we like to see? With @calvinbrown085 's work we have reading from a file (files1). I could see adding something like:
I'd be happy to commit to creating these exercises (as well as any others you folks suggest). |
IMO, writing a new file would be a good exercise, I also agree that your stdio ones would be good too! |
May be also these common use case :
|
I think that we can add a whole IO section with at least 2 exercises :) Open to pull requests :D |
I can try and work on a new io section if this is still wanted |
@frroossst Go ahead! I think that we can have 3 small exercises about dealing with files:
In all of these exercises, the user should complete the body of a function which takes a path as argument. Input files should be created in tests and the path is then passed to the user function. In the last exercise with appending, we can teach about the I think that an exercise about
|
I'm a little confused as to what is meant by manually opening/reading the files manually. I wrote a little sample, please tell me if it meets expectations. fn main() {}
#[cfg(test)]
mod test {
use fs;
#[test]
fn can_you_read_in_rust() {
let content = fs::read("./ferris.txt").unwrap();
// let _ = fs::???("./ferris.txt").unwrap();
let expect: Vec<u8> = vec![
102, 101, 114, 114, 105, 115, 10,
];
assert_eq!(expect, content)
}
#[test]
fn read_a_string_directly() {
// you might've noticed in the previous test, that the file
// reads in a Vec<u8>, hey! that doesn't look like a string
// No, no it doesn't, afterall evrything in a computer is bits
// and bytes, but, Rust provides us with a convienient method
// to read strings directly
let content = fs::read_to_string("./ferris.txt").unwrap();
assert_eq!("ferris", content)
}
} |
With manually opening and then reading a file, I mean something like this: let mut file = File::open("Cargo.toml")?;
let mut content = String::new();
file.read_to_string(&mut content)?;
println!("{content}"); The alternative is to use the specialized, but less flexible functions from let content = fs::read_to_string("Cargo.toml")?;
println!("{content}"); Some points:
|
Hey, @mo8it sorry school has been super busy lately, didn't get much free time. fn main() {}
#[cfg(test)]
mod test {
use std::io::prelude::*;
use std::fs::File;
#[test]
fn can_you_read_in_rust() {
// the user enters the name of the file to open
// the unwrap will be missing for the File::open
let mut file = File::open("ferris.txt").unwrap();
let mut content = String::new();
// the user will fill in the read_to_string method
file.read_to_string(&mut content).unwrap();
assert_eq!(content.len(), 10);
}
#[test]
fn can_you_write_in_rust() {
let msg = "hello world!";
// here the user will enter the path of the file
let path = "ferris.txt";
// the user will fill the create method
let mut file = File::create(path).unwrap();
// the unwrap will be missing here
file.write_all(msg.as_bytes()).unwrap();
}
#[test]
fn can_you_append_in_rust() {
todo!()
}
} I did have a question, how would we verify that a file called ferris.txt would exist when testing read or how do we verify that the user created a file. The obvious thing is when the test start create the necessary file and in the assert check if the file exists for the writing test. I was wondering if there were better, more elegant or more idiomatic ways to deal with this. |
Should I make a pull request to add a new exercise? |
It would be much better to let users write their code in normal functions that are then used inside tests. These tests shouldn't be changed by users. Before running the function, the tests would make sure that the file either exists or not (depending on what the user should expect). @frroossst you are welcome to create a PR. I will start reviewing and merging PRs related to new exercises in December. Then I can release Rustlings v7 in the new year :D |
Add Exercises on Stdio, Read, Write and Files.
The text was updated successfully, but these errors were encountered: