mirror of
https://gitea.invidious.io/iv-org/shard-spectator.git
synced 2024-08-15 00:53:35 +00:00
Merge branch 'master' into release/0.10
This commit is contained in:
commit
3d702f9bc6
6 changed files with 57 additions and 7 deletions
14
CHANGELOG.md
14
CHANGELOG.md
|
@ -27,6 +27,14 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
### Removed
|
### Removed
|
||||||
- Removed one-liner it syntax without braces (block).
|
- Removed one-liner it syntax without braces (block).
|
||||||
|
|
||||||
|
## [0.9.34] - 2021-03-31
|
||||||
|
### Changed
|
||||||
|
- Allow filtering examples by using any line in the example block. [#19](https://github.com/icy-arctic-fox/spectator/issues/19) Thanks @matthewmcgarvey !
|
||||||
|
|
||||||
|
## [0.9.33] - 2021-03-22
|
||||||
|
### Changed
|
||||||
|
- Target Crystal 1.0
|
||||||
|
|
||||||
## [0.9.32] - 2021-02-03
|
## [0.9.32] - 2021-02-03
|
||||||
### Fixed
|
### Fixed
|
||||||
- Fix source reference with brace-less example syntax. [#20](https://github.com/icy-arctic-fox/spectator/issues/20)
|
- Fix source reference with brace-less example syntax. [#20](https://github.com/icy-arctic-fox/spectator/issues/20)
|
||||||
|
@ -264,8 +272,10 @@ This has been changed so that it compiles and raises an error at runtime with a
|
||||||
First version ready for public use.
|
First version ready for public use.
|
||||||
|
|
||||||
|
|
||||||
[Unreleased]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.32...HEAD
|
[Unreleased]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.34...HEAD
|
||||||
[0.9.31]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.31...v0.9.32
|
[0.9.34]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.33...v0.9.34
|
||||||
|
[0.9.33]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.32...v0.9.33
|
||||||
|
[0.9.32]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.31...v0.9.32
|
||||||
[0.9.31]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.30...v0.9.31
|
[0.9.31]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.30...v0.9.31
|
||||||
[0.9.30]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.29...v0.9.30
|
[0.9.30]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.29...v0.9.30
|
||||||
[0.9.29]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.28...v0.9.29
|
[0.9.29]: https://gitlab.com/arctic-fox/spectator/-/compare/v0.9.28...v0.9.29
|
||||||
|
|
|
@ -6,7 +6,7 @@ description: |
|
||||||
authors:
|
authors:
|
||||||
- Michael Miller <icy.arctic.fox@gmail.com>
|
- Michael Miller <icy.arctic.fox@gmail.com>
|
||||||
|
|
||||||
crystal: 0.35.1
|
crystal: 1.0.0
|
||||||
|
|
||||||
license: MIT
|
license: MIT
|
||||||
|
|
||||||
|
|
32
spec/line_number_spec.cr
Normal file
32
spec/line_number_spec.cr
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
require "./spec_helper"
|
||||||
|
|
||||||
|
Spectator.describe Spectator do
|
||||||
|
let(current_example) { ::Spectator::Example.current }
|
||||||
|
subject(source) { current_example.source }
|
||||||
|
|
||||||
|
context "line numbers" do
|
||||||
|
it "contains starting line of spec" do
|
||||||
|
expect(source.line).to eq(__LINE__ - 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "contains ending line of spec" do
|
||||||
|
expect(source.end_line).to eq(__LINE__ + 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
it "handles multiple lines and examples" do
|
||||||
|
# Offset is important.
|
||||||
|
expect(source.line).to eq(__LINE__ - 2)
|
||||||
|
# This line fails, refer to https://github.com/crystal-lang/crystal/issues/10562
|
||||||
|
# expect(source.end_line).to eq(__LINE__ + 2)
|
||||||
|
# Offset is still important.
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
context "file names" do
|
||||||
|
subject { source.file }
|
||||||
|
|
||||||
|
it "match source code" do
|
||||||
|
is_expected.to eq(__FILE__)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -47,7 +47,7 @@ module Spectator::DSL
|
||||||
|
|
||||||
::Spectator::DSL::Builder.add_example(
|
::Spectator::DSL::Builder.add_example(
|
||||||
_spectator_example_name(\{{what}}),
|
_spectator_example_name(\{{what}}),
|
||||||
::Spectator::Source.new(\{{block.filename}}, \{{block.line_number}}),
|
::Spectator::Source.new(\{{block.filename}}, \{{block.line_number}}, \{{block.end_line_number}}),
|
||||||
new.as(::Spectator::Context),
|
new.as(::Spectator::Context),
|
||||||
\%tags
|
\%tags
|
||||||
) do |example|
|
) do |example|
|
||||||
|
|
|
@ -7,7 +7,9 @@ module Spectator
|
||||||
|
|
||||||
# Checks whether the example satisfies the filter.
|
# Checks whether the example satisfies the filter.
|
||||||
def includes?(example) : Bool
|
def includes?(example) : Bool
|
||||||
@line == example.source.line
|
start_line = example.source.line
|
||||||
|
end_line = example.source.end_line
|
||||||
|
(start_line..end_line).covers?(@line)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -6,11 +6,17 @@ module Spectator
|
||||||
# Absolute file path.
|
# Absolute file path.
|
||||||
getter file : String
|
getter file : String
|
||||||
|
|
||||||
# Line number in the file.
|
# Starting line number in the file.
|
||||||
getter line : Int32
|
getter line : Int32
|
||||||
|
|
||||||
|
# Ending line number in the file.
|
||||||
|
getter end_line : Int32
|
||||||
|
|
||||||
# Creates the source.
|
# Creates the source.
|
||||||
def initialize(@file, @line)
|
def initialize(@file, @line, end_line = nil)
|
||||||
|
# if an end line is not provided,
|
||||||
|
# make the end line the same as the start line
|
||||||
|
@end_line = end_line || @line
|
||||||
end
|
end
|
||||||
|
|
||||||
# Parses a source from a string.
|
# Parses a source from a string.
|
||||||
|
|
Loading…
Reference in a new issue