Initial Commit
This commit is contained in:
44
scheme/hello-world/README.md
Normal file
44
scheme/hello-world/README.md
Normal file
@@ -0,0 +1,44 @@
|
||||
# Hello World
|
||||
|
||||
Write a program that greets the user by name, or by saying "Hello, World!" if no name is given.
|
||||
|
||||
["Hello, World!"](http://en.wikipedia.org/wiki/%22Hello,_world!%22_program) is the traditional first program for beginning programming in a new language.
|
||||
|
||||
**Note:** You can skip this exercise by running:
|
||||
|
||||
exercism skip $LANGUAGE hello-world
|
||||
|
||||
## Specification
|
||||
|
||||
The `Hello World!` program will greet me, the caller.
|
||||
|
||||
If I tell the program my name is Alice, it will greet me by saying "Hello, Alice!".
|
||||
|
||||
If I neglect to give it my name, it will greet me by saying "Hello, World!"
|
||||
|
||||
## Test-Driven Development
|
||||
|
||||
As programmers mature, they eventually want to test their code.
|
||||
|
||||
Here at Exercism we simulate [Test-Driven Development](http://en.wikipedia.org/wiki/Test-driven_development) (TDD), where you write your tests before writing any functionality. The simulation comes in the form of a pre-written test suite, which will signal that you have solved the problem.
|
||||
|
||||
It will also provide you with a safety net to explore other solutions without breaking the functionality.
|
||||
|
||||
### A typical TDD workflow on Exercism:
|
||||
|
||||
1. Run the test file and pick one test that's failing.
|
||||
2. Write some code to fix the test you picked.
|
||||
3. Re-run the tests to confirm the test is now passing.
|
||||
4. Repeat from step 1.
|
||||
5. [Submit your solution](http://help.exercism.io/submitting-exercises.html).
|
||||
|
||||
## Instructions
|
||||
|
||||
Submissions are encouraged to be general, within reason. Having said that, it's also important not to over-engineer a solution.
|
||||
|
||||
It's important to remember that the goal is to make code as expressive and readable as we can. However, solutions to the hello-world exercise will be not be reviewed by a person, but by rikki- the robot, who will offer an encouraging word.
|
||||
|
||||
|
||||
## Source
|
||||
|
||||
This is a program to introduce users to using Exercism [view source](http://en.wikipedia.org/wiki/%22Hello,_world!%22_program)
|
21
scheme/hello-world/hello-world-test.scm
Normal file
21
scheme/hello-world/hello-world-test.scm
Normal file
@@ -0,0 +1,21 @@
|
||||
;; Load SRFI-64 lightweight testing specification
|
||||
(use-modules (srfi srfi-64))
|
||||
|
||||
;; Suppress log file output. To write logs, comment out the following line:
|
||||
(module-define! (resolve-module '(srfi srfi-64)) 'test-log-to-file #f)
|
||||
|
||||
;; Require module
|
||||
(add-to-load-path (dirname (current-filename)))
|
||||
(use-modules (hello-world))
|
||||
|
||||
(test-begin "hello-world")
|
||||
|
||||
(test-assert "Called with no args returns hello world"
|
||||
(equal? (hello)
|
||||
"Hello, World!"))
|
||||
|
||||
(test-assert "Called with an arg returns hello arg"
|
||||
(equal? (hello "exercism")
|
||||
"Hello, exercism!"))
|
||||
|
||||
(test-end "hello-world")
|
2
scheme/hello-world/hello-world.scm
Normal file
2
scheme/hello-world/hello-world.scm
Normal file
@@ -0,0 +1,2 @@
|
||||
(define-module (hello-world)
|
||||
#:export (hello))
|
Reference in New Issue
Block a user