require "spec_helper" require "open3" RSpec.describe Asciidoctor::Standoc do it "processes pass blocks" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} ++++ X > Y ++++ INPUT #{BLANK_HDR} X > Y OUTPUT end it "processes open blocks" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} -- x y z -- INPUT #{BLANK_HDR}

x

y

z

OUTPUT end =begin it "processes stem blocks" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [stem%inequality] ++++ r = 1 % r = 1 % ++++ [stem%unnumbered] ++++ F Α ++++ [latexmath,subsequence=A] ++++ M = \\begin{bmatrix} -\\sin λ_0 & \\cos λ_0 & 0 \\\\ -\\sin φ_0 \\cos λ_0 & -\\sin φ_0 \\sin λ_0 & \\cos φ_0 \\\\ \\cos φ_0 \\cos λ_0 & \\cos φ_0 \\sin λ_0 & \\sin φ_0 \\end{bmatrix} ++++ INPUT #{BLANK_HDR} r=1%r=1% F Α M = [ - sin λ 0 cos λ 0 0 - sin φ 0 cos λ 0 - sin φ 0 sin λ 0 cos φ 0 cos φ 0 cos λ 0 cos φ 0 sin λ 0 sin φ 0 ] OUTPUT end =end it "ignores review blocks unless document is in draft mode" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [[foreword]] .Foreword Foreword [reviewer=ISO,date=20170101,from=foreword,to=foreword] **** A Foreword shall appear in each document. The generic text is shown here. It does not contain requirements, recommendations or permissions. For further information on the Foreword, see *ISO/IEC Directives, Part 2, 2016, Clause 12.* **** INPUT #{BLANK_HDR}

Foreword

OUTPUT end it "processes review blocks if document is in draft mode" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" = Document title Author :docfile: test.adoc :nodoc: :novalid: :draft: 1.2 [[foreword]] .Foreword Foreword [reviewer=ISO,date=20170101,from=foreword,to=foreword] **** A Foreword shall appear in each document. The generic text is shown here. It does not contain requirements, recommendations or permissions. For further information on the Foreword, see *ISO/IEC Directives, Part 2, 2016, Clause 12.* **** INPUT Document title 1.2 en published #{Date.today.year} article

Foreword

A Foreword shall appear in each document. The generic text is shown here. It does not contain requirements, recommendations or permissions.

For further information on the Foreword, see ISO/IEC Directives, Part 2, 2016, Clause 12.

OUTPUT end it "processes term notes" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 NOTE: This is a note INPUT #{BLANK_HDR} Terms and definitions

For the purposes of this document, the following terms and definitions apply.

Term1

This is a note

OUTPUT end it "processes term notes as plain notes in nonterm clauses" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions [.nonterm] === Term1 NOTE: This is a note INPUT #{BLANK_HDR} Terms and definitions

No terms and definitions are listed in this document.

Term1

This is a note

OUTPUT end it "processes term notes as plain notes in definitions subclauses of terms & definitions" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 === Symbols NOTE: This is a note INPUT #{BLANK_HDR} Terms, definitions, symbols and abbreviated terms

For the purposes of this document, the following terms and definitions apply.

Term1 Symbols

This is a note

OUTPUT end it "processes notes" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} NOTE: This is a note == Clause 1 NOTE: This is a note INPUT #{BLANK_HDR} Foreword

This is a note

Clause 1

This is a note

OUTPUT end it "processes literals" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} .... .... INPUT #{BLANK_HDR}
<LITERAL>
OUTPUT end it "processes simple admonitions with Asciidoc names" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} CAUTION: Only use paddy or parboiled rice for the determination of husked rice yield. INPUT #{BLANK_HDR}

Only use paddy or parboiled rice for the determination of husked rice yield.

OUTPUT end it "processes complex admonitions with non-Asciidoc names" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [CAUTION,type=Safety Precautions] .Precautions ==== While werewolves are hardy community members, keep in mind the following dietary concerns: . They are allergic to cinnamon. . More than two glasses of orange juice in 24 hours makes them howl in harmony with alarms and sirens. . Celery makes them sad. ==== INPUT #{BLANK_HDR} Precautions

While werewolves are hardy community members, keep in mind the following dietary concerns:

  1. They are allergic to cinnamon.

  2. More than two glasses of orange juice in 24 hours makes them howl in harmony with alarms and sirens.

  3. Celery makes them sad.

OUTPUT end it "processes term examples" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 [example] This is an example INPUT #{BLANK_HDR} Terms and definitions

For the purposes of this document, the following terms and definitions apply.

Term1

This is an example

OUTPUT end it "processes term examples as plain examples in nonterm clauses" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions [.nonterm] === Term1 [example] This is an example INPUT #{BLANK_HDR} Terms and definitions

No terms and definitions are listed in this document.

Term1

This is an example

OUTPUT end it "processes term examples as plain examples in definitions subclauses of terms & definitions" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 === Symbols [example] This is an example INPUT #{BLANK_HDR} Terms, definitions, symbols and abbreviated terms

For the purposes of this document, the following terms and definitions apply.

Term1 Symbols

This is an example

OUTPUT end it "processes examples" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [example,subsequence=A] .Title ==== This is an example Amen ==== [example%unnumbered] ==== This is another example ==== INPUT #{BLANK_HDR} Title

This is an example

Amen

This is another example

OUTPUT end it "processes preambles" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} This is a preamble == Section 1 INPUT #{BLANK_HDR} Foreword

This is a preamble

Section 1 OUTPUT end it "processes preambles with titles" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} .Preamble This is a preamble == Section 1 INPUT #{BLANK_HDR} Preamble

This is a preamble

Section 1 OUTPUT end it "processes subfigures" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [[figureC-2]] .Stages of gelatinization ==== .Initial stages: No grains are fully gelatinized (ungelatinized starch granules are visible inside the kernels) image::spec/examples/rice_images/rice_image3_1.png[] .Intermediate stages: Some fully gelatinized kernels are visible image::spec/examples/rice_images/rice_image3_2.png[] .Final stages: All kernels are fully gelatinized image::spec/examples/rice_images/rice_image3_3.png[] ==== INPUT #{BLANK_HDR}
Stages of gelatinization
Initial stages: No grains are fully gelatinized (ungelatinized starch granules are visible inside the kernels)
Intermediate stages: Some fully gelatinized kernels are visible
Final stages: All kernels are fully gelatinized
OUTPUT end it "processes figures within examples" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [[figureC-2]] .Stages of gelatinization ==== .Initial stages: No grains are fully gelatinized (ungelatinized starch granules are visible inside the kernels) image::spec/examples/rice_images/rice_image3_1.png[] Text .Intermediate stages: Some fully gelatinized kernels are visible image::spec/examples/rice_images/rice_image3_2.png[] .Final stages: All kernels are fully gelatinized image::spec/examples/rice_images/rice_image3_3.png[] ==== INPUT #{BLANK_HDR} Stages of gelatinization
Initial stages: No grains are fully gelatinized (ungelatinized starch granules are visible inside the kernels)

Text

Intermediate stages: Some fully gelatinized kernels are visible
Final stages: All kernels are fully gelatinized
OUTPUT end it "processes images" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [%unnumbered] .Split-it-right sample divider image::spec/examples/rice_images/rice_image1.png[alttext] INPUT #{BLANK_HDR}
Split-it-right sample divider alttext
OUTPUT end it "processes data URI images" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [subsequence=A] .Split-it-right sample divider image::[alttext] INPUT #{BLANK_HDR}
Split-it-right sample divider alttext
OUTPUT end it "accepts attributes on images" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [height=4,width=3,alt="IMAGE",filename="riceimg1.png"] image::spec/examples/rice_images/rice_image1.png[] INPUT #{BLANK_HDR}
IMAGE
OUTPUT end it "accepts auto for width and height attributes on images" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [height=4,width=auto] image::spec/examples/rice_images/rice_image1.png[] INPUT #{BLANK_HDR}
OUTPUT end it "processes inline images with width and height attributes on images" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} Hello image:spec/examples/rice_images/rice_image1.png[alt, 4, 3], how are you? INPUT #{BLANK_HDR}

Hello alt, how are you?

OUTPUT end it "processes images as datauri" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to include '

This para is right-aligned.

OUTPUT end it "processes blockquotes" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [quote, ISO, "ISO7301,section 1"] ____ Block quotation ____ INPUT #{BLANK_HDR} 1 ISO

Block quotation

OUTPUT end it "processes source code" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} .Caption [source,ruby,filename=sourcecode1.rb] -- puts "Hello, world." %w{a b c}.each do |x| puts x end -- INPUT #{BLANK_HDR} Captionputs "Hello, world." %w{a b c}.each do |x| puts x end OUTPUT end it "processes callouts" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} [source,ruby] -- puts "Hello, world." <1> %w{a b c}.each do |x| puts x <2> end -- <1> This is one callout <2> This is another callout INPUT #{BLANK_HDR} puts "Hello, world." 1 %w{a b c}.each do |x| puts x 2 end

This is one callout

This is another callout

OUTPUT end it "processes unmodified term sources" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 [.source] <> INPUT #{BLANK_HDR} Terms and definitions

For the purposes of this document, the following terms and definitions apply.

Term1 1
OUTPUT end it "processes modified term sources" do expect(strip_guid(Asciidoctor.convert(<<~"INPUT", backend: :standoc, header_footer: true))).to be_equivalent_to <<~"OUTPUT" #{ASCIIDOC_BLANK_HDR} == Terms and Definitions === Term1 [.source] <>, with adjustments INPUT #{BLANK_HDR} Terms and definitions

For the purposes of this document, the following terms and definitions apply.

Term1 1

with adjustments

OUTPUT end it "processes recommendation" do input = <<~"INPUT" #{ASCIIDOC_BLANK_HDR} [.recommendation,label="/ogc/recommendation/wfs/2",subject="user",inherit="/ss/584/2015/level/1",options="unnumbered"] ==== I recommend this ==== INPUT output = <<~"OUTPUT" #{BLANK_HDR} user /ss/584/2015/level/1

I recommend this

OUTPUT expect(strip_guid(Asciidoctor.convert(input, backend: :standoc, header_footer: true))).to be_equivalent_to output end it "processes requirement" do input = <<~"INPUT" #{ASCIIDOC_BLANK_HDR} [.requirement,subsequence="A"] .Title ==== I recommend this ==== INPUT output = <<~"OUTPUT" #{BLANK_HDR} Title

I recommend this

OUTPUT expect(strip_guid(Asciidoctor.convert(input, backend: :standoc, header_footer: true))).to be_equivalent_to output end it "processes permission" do input = <<~"INPUT" #{ASCIIDOC_BLANK_HDR} [.permission] ==== I recommend this ==== INPUT output = <<~"OUTPUT" #{BLANK_HDR}

I recommend this

OUTPUT expect(strip_guid(Asciidoctor.convert(input, backend: :standoc, header_footer: true))).to be_equivalent_to output end it "processes nested permissions" do input = <<~"INPUT" #{ASCIIDOC_BLANK_HDR} [.permission] ==== I permit this ===== Example 2 ===== [.permission] ===== I also permit this ===== ==== INPUT output = <<~"OUTPUT" #{BLANK_HDR}

I permit this

Example 2

I also permit this

OUTPUT expect(strip_guid(Asciidoctor.convert(input, backend: :standoc, header_footer: true))).to be_equivalent_to output end it "processes recommendation with internal markup of structure" do input = <<~"INPUT" #{ASCIIDOC_BLANK_HDR} [.recommendation,label="/ogc/recommendation/wfs/2",subject="user",classification="control-class:Technical;priority:P0;family:System and Communications Protection,System and Communications Protocols",obligation="permission,recommendation",filename="reqt1.rq"] ==== I recommend _this_. [.specification,type="tabular"] -- This is the object of the recommendation: |=== |Object |Value |Mission | Accomplished |=== -- As for the measurement targets, [.measurement-target] -- The measurement target shall be measured as: [stem] ++++ r/1 = 0 ++++ -- [.verification] -- The following code will be run for verification: [source,CoreRoot] ---- CoreRoot(success): HttpResponse if (success) recommendation(label: success-response) end ---- -- [.import%exclude] -- [source,CoreRoot] ---- success-response() ---- -- ==== INPUT output = <<~"OUTPUT" #{BLANK_HDR} user control-classTechnicalpriorityP0familySystem and Communications ProtectionfamilySystem and Communications Protocols

I recommend this.

This is the object of the recommendation:

Object Value
Mission Accomplished

As for the measurement targets,

The measurement target shall be measured as:

r1=0

The following code will be run for verification:

CoreRoot(success): HttpResponse if (success) recommendation(label: success-response) end
success-response()
OUTPUT expect(strip_guid(Asciidoctor.convert(input, backend: :standoc, header_footer: true))).to be_equivalent_to output end end