| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836 | ;;; test-org.el --- tests for org.el;; Copyright (c)  David Maus;; Authors: David Maus;; This file is not part of GNU Emacs.;; This program is free software; you can redistribute it and/or modify;; it under the terms of the GNU General Public License as published by;; the Free Software Foundation, either version 3 of the License, or;; (at your option) any later version.;; This program is distributed in the hope that it will be useful,;; but WITHOUT ANY WARRANTY; without even the implied warranty of;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the;; GNU General Public License for more details.;; You should have received a copy of the GNU General Public License;; along with this program.  If not, see <http://www.gnu.org/licenses/>.;;; Comments:;; Template test file for Org-mode tests;;; Code:;;; Comments(ert-deftest test-org/toggle-comment ()  "Test `org-toggle-comment' specifications."  ;; Simple headline.  (should   (equal "* Test"	  (org-test-with-temp-text "* COMMENT Test"	    (org-toggle-comment)	    (buffer-string))))  (should   (equal "* COMMENT Test"	  (org-test-with-temp-text "* Test"	    (org-toggle-comment)	    (buffer-string))))  ;; Headline with a regular keyword.  (should   (equal "* TODO Test"	  (org-test-with-temp-text "* TODO COMMENT Test"	    (org-toggle-comment)	    (buffer-string))))  (should   (equal "* TODO COMMENT Test"	  (org-test-with-temp-text "* TODO Test"	    (org-toggle-comment)	    (buffer-string))))  ;; Empty headline.  (should   (equal "* "	  (org-test-with-temp-text "* COMMENT"	    (org-toggle-comment)	    (buffer-string))))  (should   (equal "* COMMENT"	  (org-test-with-temp-text "* "	    (org-toggle-comment)	    (buffer-string))))  ;; Headline with a single keyword.  (should   (equal "* TODO "	  (org-test-with-temp-text "* TODO COMMENT"	    (org-toggle-comment)	    (buffer-string))))  (should   (equal "* TODO COMMENT"	  (org-test-with-temp-text "* TODO"	    (org-toggle-comment)	    (buffer-string))))  ;; Headline with a keyword, a priority cookie and contents.  (should   (equal "* TODO [#A] Headline"	  (org-test-with-temp-text "* TODO [#A] COMMENT Headline"	    (org-toggle-comment)	    (buffer-string))))  (should   (equal "* TODO [#A] COMMENT Headline"	  (org-test-with-temp-text "* TODO [#A] Headline"	    (org-toggle-comment)	    (buffer-string)))))(ert-deftest test-org/comment-dwim ()  "Test `comment-dwim' behaviour in an Org buffer."  ;; No region selected, no comment on current line and line not  ;; empty: insert comment on line above.  (should   (equal "# \nComment"	  (org-test-with-temp-text "Comment"	    (progn (call-interactively 'comment-dwim)		   (buffer-string)))))  ;; No region selected, no comment on current line and line empty:  ;; insert comment on this line.  (should   (equal "# \nParagraph"	  (org-test-with-temp-text "\nParagraph"	    (progn (call-interactively 'comment-dwim)		   (buffer-string)))))  ;; No region selected, and a comment on this line: indent it.  (should   (equal "* Headline\n  # Comment"	  (org-test-with-temp-text "* Headline\n# Comment"	    (progn (forward-line)		   (let ((org-adapt-indentation t))		     (call-interactively 'comment-dwim))		   (buffer-string)))))  ;; Also recognize single # at column 0 as comments.  (should   (equal "# Comment"	  (org-test-with-temp-text "# Comment"	    (progn (forward-line)		   (call-interactively 'comment-dwim)		   (buffer-string)))))  ;; Region selected and only comments and blank lines within it:  ;; un-comment all commented lines.  (should   (equal "Comment 1\n\nComment 2"	  (org-test-with-temp-text "# Comment 1\n\n# Comment 2"	    (progn	      (transient-mark-mode 1)	      (push-mark (point) t t)	      (goto-char (point-max))	      (call-interactively 'comment-dwim)	      (buffer-string)))))  ;; Region selected without comments: comment all lines if  ;; `comment-empty-lines' is non-nil, only non-blank lines otherwise.  (should   (equal "# Comment 1\n\n# Comment 2"	  (org-test-with-temp-text "Comment 1\n\nComment 2"	    (progn	      (transient-mark-mode 1)	      (push-mark (point) t t)	      (goto-char (point-max))	      (let ((comment-empty-lines nil))		(call-interactively 'comment-dwim))	      (buffer-string)))))  (should   (equal "# Comment 1\n# \n# Comment 2"	  (org-test-with-temp-text "Comment 1\n\nComment 2"	    (progn	      (transient-mark-mode 1)	      (push-mark (point) t t)	      (goto-char (point-max))	      (let ((comment-empty-lines t))		(call-interactively 'comment-dwim))	      (buffer-string)))))  ;; In front of a keyword without region, insert a new comment.  (should   (equal "# \n#+KEYWORD: value"	  (org-test-with-temp-text "#+KEYWORD: value"	    (progn (call-interactively 'comment-dwim)		   (buffer-string)))))  ;; In a source block, use appropriate syntax.  (should   (equal "  ;; "	  (org-test-with-temp-text "#+BEGIN_SRC emacs-lisp\n\n#+END_SRC"	    (forward-line)	    (let ((org-edit-src-content-indentation 2))	      (call-interactively 'comment-dwim))	    (buffer-substring-no-properties (line-beginning-position) (point)))))  (should   (equal "#+BEGIN_SRC emacs-lisp\n  ;; a\n  ;; b\n#+END_SRC"	  (org-test-with-temp-text "#+BEGIN_SRC emacs-lisp\na\nb\n#+END_SRC"	    (forward-line)	    (transient-mark-mode 1)	    (push-mark (point) t t)	    (forward-line 2)	    (let ((org-edit-src-content-indentation 2))	      (call-interactively 'comment-dwim))	    (buffer-string)))));;; Date and time analysis(ert-deftest test-org/org-read-date ()  "Test `org-read-date' specifications."  ;; Parse ISO date with abbreviated year and month.  (should (equal "2012-03-29 16:40"		 (let ((org-time-was-given t))		   (org-read-date t nil "12-3-29 16:40"))))  ;; Parse Europeans dates.  (should (equal "2012-03-29 16:40"		 (let ((org-time-was-given t))		   (org-read-date t nil "29.03.2012 16:40"))))  ;; Parse Europeans dates without year.  (should (string-match "2[0-9]\\{3\\}-03-29 16:40"			(let ((org-time-was-given t))			  (org-read-date t nil "29.03. 16:40")))))(ert-deftest test-org/org-parse-time-string ()  "Test `org-parse-time-string'."  (should (equal (org-parse-time-string "2012-03-29 16:40")		 '(0 40 16 29 3 2012 nil nil nil)))  (should (equal (org-parse-time-string "[2012-03-29 16:40]")		 '(0 40 16 29 3 2012 nil nil nil)))  (should (equal (org-parse-time-string "<2012-03-29 16:40>")		 '(0 40 16 29 3 2012 nil nil nil)))  (should (equal (org-parse-time-string "<2012-03-29>")		 '(0 0 0 29 3 2012 nil nil nil)))  (should (equal (org-parse-time-string "<2012-03-29>" t)		 '(0 nil nil 29 3 2012 nil nil nil))));;; Filling(ert-deftest test-org/fill-paragraph ()  "Test `org-fill-paragraph' specifications."  ;; At an Org table, align it.  (should   (equal "| a |\n"	  (org-test-with-temp-text "|a|"	    (org-fill-paragraph)	    (buffer-string))))  (should   (equal "#+name: table\n| a |\n"	  (org-test-with-temp-text "#+name: table\n| a |"	    (org-fill-paragraph)	    (buffer-string))))  ;; At a paragraph, preserve line breaks.  (org-test-with-temp-text "some \\\\\nlong\ntext"    (let ((fill-column 20))      (org-fill-paragraph)      (should (equal (buffer-string) "some \\\\\nlong text"))))  ;; Correctly fill a paragraph when point is at its very end.  (should   (equal "A B"	  (org-test-with-temp-text "A\nB"	    (let ((fill-column 20))	      (goto-char (point-max))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Correctly fill the last paragraph of a greater element.  (should   (equal "#+BEGIN_CENTER\n- 012345\n  789\n#+END_CENTER"	  (org-test-with-temp-text "#+BEGIN_CENTER\n- 012345 789\n#+END_CENTER"	    (let ((fill-column 8))	      (forward-line)	      (end-of-line)	      (org-fill-paragraph)	      (buffer-string)))))  ;; Correctly fill an element in a narrowed buffer.  (should   (equal "01234\n6"	  (org-test-with-temp-text "01234 6789"	    (let ((fill-column 5))	      (narrow-to-region 1 8)	      (org-fill-paragraph)	      (buffer-string)))))  ;; Handle `adaptive-fill-regexp' in paragraphs.  (should   (equal "> a b"	  (org-test-with-temp-text "> a\n> b"	    (let ((fill-column 5)		  (adaptive-fill-regexp "[ \t]*>+[ \t]*"))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Special case: Fill first paragraph when point is at an item or  ;; a plain-list or a footnote reference.  (should   (equal "- A B"	  (org-test-with-temp-text "- A\n  B"	    (let ((fill-column 20))	      (org-fill-paragraph)	      (buffer-string)))))  (should   (equal "[fn:1] A B"	  (org-test-with-temp-text "[fn:1] A\nB"	    (let ((fill-column 20))	      (org-fill-paragraph)	      (buffer-string)))))  (org-test-with-temp-text "#+BEGIN_VERSE\nSome \\\\\nlong\ntext\n#+END_VERSE"    (let ((fill-column 20))      (org-fill-paragraph)      (should (equal (buffer-string)		     "#+BEGIN_VERSE\nSome \\\\\nlong\ntext\n#+END_VERSE"))))  ;; Fill contents of `comment-block' elements.  (should   (equal    (org-test-with-temp-text "#+BEGIN_COMMENT\nSome\ntext\n#+END_COMMENT"      (let ((fill-column 20))	(forward-line)	(org-fill-paragraph)	(buffer-string)))    "#+BEGIN_COMMENT\nSome text\n#+END_COMMENT"))  ;; Fill `comment' elements.  (should   (equal "  # A B"	  (org-test-with-temp-text "  # A\n  # B"	    (let ((fill-column 20))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Do not mix consecutive comments when filling one of them.  (should   (equal "# A B\n\n# C"	  (org-test-with-temp-text "# A\n# B\n\n# C"	    (let ((fill-column 20))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Use commented empty lines as separators when filling comments.  (should   (equal "# A B\n#\n# C"	  (org-test-with-temp-text "# A\n# B\n#\n# C"	    (let ((fill-column 20))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Handle `adaptive-fill-regexp' in comments.  (should   (equal "# > a b"	  (org-test-with-temp-text "# > a\n# > b"	    (let ((fill-column 20)		  (adaptive-fill-regexp "[ \t]*>+[ \t]*"))	      (org-fill-paragraph)	      (buffer-string)))))  ;; Do nothing at affiliated keywords.  (org-test-with-temp-text "#+NAME: para\nSome\ntext."    (let ((fill-column 20))      (org-fill-paragraph)      (should (equal (buffer-string) "#+NAME: para\nSome\ntext."))))  ;; Do not move point after table when filling a table.  (should-not   (org-test-with-temp-text "| a | b |\n| c | d |\n"     (forward-char)     (org-fill-paragraph)     (eobp))))(ert-deftest test-org/auto-fill-function ()  "Test auto-filling features."  ;; Auto fill paragraph.  (should   (equal "12345\n7890"	  (org-test-with-temp-text "12345 7890"	    (let ((fill-column 5))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Auto fill first paragraph in an item.  (should   (equal "- 12345\n  7890"	  (org-test-with-temp-text "- 12345 7890"	    (let ((fill-column 7))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Auto fill paragraph when `adaptive-fill-regexp' matches.  (should   (equal "> 12345\n  7890"	  (org-test-with-temp-text "> 12345 7890"	    (let ((fill-column 10)		  (adaptive-fill-regexp "[ \t]*>+[ \t]*")		  (adaptive-fill-first-line-regexp "\\`[ 	]*\\'"))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  (should   (equal "> 12345\n> 12345\n> 7890"	  (org-test-with-temp-text "> 12345\n> 12345 7890"	    (let ((fill-column 10)		  (adaptive-fill-regexp "[ \t]*>+[ \t]*"))	      (goto-char (point-max))	      (org-auto-fill-function)	      (buffer-string)))))  (should-not   (equal " 12345\n *12345\n *12345"	  (org-test-with-temp-text " 12345\n *12345 12345"	    (let ((fill-column 10)		  (adaptive-fill-regexp "[ \t]*>+[ \t]*"))	      (goto-char (point-max))	      (org-auto-fill-function)	      (buffer-string)))))  ;; Auto fill comments.  (should   (equal "  # 12345\n  # 7890"	  (org-test-with-temp-text "  # 12345 7890"	    (let ((fill-column 10))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; A hash within a line isn't a comment.  (should-not   (equal "12345 # 7890\n# 1"	  (org-test-with-temp-text "12345 # 7890 1"	    (let ((fill-column 12))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Correctly interpret empty prefix.  (should-not   (equal "# a\n# b\nRegular\n# paragraph"	  (org-test-with-temp-text "# a\n# b\nRegular paragraph"	    (let ((fill-column 12))	      (end-of-line 3)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Comment block: auto fill contents.  (should   (equal "#+BEGIN_COMMENT\n12345\n7890\n#+END_COMMENT"	  (org-test-with-temp-text "#+BEGIN_COMMENT\n12345 7890\n#+END_COMMENT"	    (let ((fill-column 5))	      (forward-line)	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  (should   (equal "#+BEGIN_COMMENT\n12345\n7890\n#+END_COMMENT"	  (org-test-with-temp-text "#+BEGIN_COMMENT\n12345 7890\n#+END_COMMENT"	    (let ((fill-column 5))	      (forward-line)	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Do not fill if a new item could be created.  (should-not   (equal "12345\n- 90"	  (org-test-with-temp-text "12345 - 90"	    (let ((fill-column 5))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Do not fill if a line break could be introduced.  (should-not   (equal "123\\\\\n7890"	  (org-test-with-temp-text "123\\\\ 7890"	    (let ((fill-column 6))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string)))))  ;; Do not fill affiliated keywords.  (should-not   (equal "#+ATTR_LATEX: ABC\nDEFGHIJKL"	  (org-test-with-temp-text "#+ATTR_LATEX: ABC DEFGHIJKL"	    (let ((fill-column 20))	      (end-of-line)	      (org-auto-fill-function)	      (buffer-string))))));;; Indentation(ert-deftest test-org/indent-line ()  "Test `org-indent-line' specifications."  ;; Do not indent footnote definitions or headlines.  (should   (zerop    (org-test-with-temp-text "* H"      (org-indent-line)      (org-get-indentation))))  (should   (zerop    (org-test-with-temp-text "[fn:1] fn"      (let ((org-adapt-indentation t)) (org-indent-line))      (org-get-indentation))))  ;; Do not indent before first headline.  (should   (zerop    (org-test-with-temp-text ""      (org-indent-line)      (org-get-indentation))))  ;; Indent according to headline level otherwise, unless  ;; `org-adapt-indentation' is nil.  (should   (= 2      (org-test-with-temp-text "* H\nA"	(forward-line)	(let ((org-adapt-indentation t)) (org-indent-line))	(org-get-indentation))))  (should   (= 2      (org-test-with-temp-text "* H\n\nA"	(forward-line)	(let ((org-adapt-indentation t)) (org-indent-line))	(org-get-indentation))))  (should   (zerop    (org-test-with-temp-text "* H\nA"      (forward-line)      (let ((org-adapt-indentation nil)) (org-indent-line))      (org-get-indentation))))  ;; Indenting preserves point position.  (should   (org-test-with-temp-text "* H\nAB"     (forward-line)     (forward-char)     (let ((org-adapt-indentation t)) (org-indent-line))     (looking-at "B")))  ;; Do not change indentation at an item.  (should   (= 1      (org-test-with-temp-text "* H\n - A"	(forward-line)	(let ((org-adapt-indentation t)) (org-indent-line))	(org-get-indentation))))  ;; On blank lines at the end of a list, indent like last element  ;; within it if the line is still in the list.  Otherwise, indent  ;; like the whole list.  (should   (= 4      (org-test-with-temp-text "* H\n- A\n  - AA\n"	(goto-char (point-max))	(let ((org-adapt-indentation t)) (org-indent-line))	(org-get-indentation))))  (should   (zerop    (org-test-with-temp-text "* H\n- A\n  - AA\n\n\n\n"      (goto-char (point-max))      (let ((org-adapt-indentation t)) (org-indent-line))      (org-get-indentation))))  ;; Likewise, on a blank line at the end of a footnote definition,  ;; indent at column 0 if line belongs to the definition.  Otherwise,  ;; indent like the definition itself.  (should   (zerop    (org-test-with-temp-text "* H\n[fn:1] Definition\n"      (goto-char (point-max))      (let ((org-adapt-indentation t)) (org-indent-line))      (org-get-indentation))))  (should   (zerop    (org-test-with-temp-text "* H\n[fn:1] Definition\n\n\n\n"      (goto-char (point-max))      (let ((org-adapt-indentation t)) (org-indent-line))      (org-get-indentation))))  ;; After the end of the contents of a greater element, indent like  ;; the beginning of the element.  (should   (= 1      (org-test-with-temp-text " #+BEGIN_CENTER\n  Contents\n#+END_CENTER"	(forward-line 2)	(org-indent-line)	(org-get-indentation))))  ;; At the first line of an element, indent like previous element's  ;; first line, ignoring footnotes definitions and inline tasks, or  ;; according to parent.  (should   (= 2      (org-test-with-temp-text "A\n\n  B\n\nC"	(goto-char (point-max))	(org-indent-line)	(org-get-indentation))))  (should   (= 1      (org-test-with-temp-text " A\n\n[fn:1] B\n\n\nC"	(goto-char (point-max))	(org-indent-line)	(org-get-indentation))))  (should   (= 1      (org-test-with-temp-text " #+BEGIN_CENTER\n  Contents\n#+END_CENTER"	(forward-line 1)	(org-indent-line)	(org-get-indentation))))  ;; Within code part of a source block, use language major mode if  ;; `org-src-tab-acts-natively' is non-nil.  Otherwise, indent  ;; according to line above.  (should   (= 6      (org-test-with-temp-text "#+BEGIN_SRC emacs-lisp\n (and A\nB)\n#+END_SRC"	(forward-line 2)	(let ((org-src-tab-acts-natively t)	      (org-edit-src-content-indentation 0))	  (org-indent-line))	(org-get-indentation))))  (should   (= 1      (org-test-with-temp-text "#+BEGIN_SRC emacs-lisp\n (and A\nB)\n#+END_SRC"	(forward-line 2)	(let ((org-src-tab-acts-natively nil)	      (org-edit-src-content-indentation 0))	  (org-indent-line))	(org-get-indentation))))  ;; Otherwise, indent like the first non-blank line above.  (should   (zerop    (org-test-with-temp-text "#+BEGIN_CENTER\nline1\n\n  line2\n#+END_CENTER"      (forward-line 3)      (org-indent-line)      (org-get-indentation))))  ;; Align node properties according to `org-property-format'.  Handle  ;; nicely empty values.  (should   (equal ":PROPERTIES:\n:key:      value\n:END:"	  (org-test-with-temp-text ":PROPERTIES:\n:key: value\n:END:"	    (forward-line)	    (let ((org-property-format "%-10s %s"))	      (org-indent-line)	      (buffer-string)))))  (should   (equal ":PROPERTIES:\n:key:\n:END:"	  (org-test-with-temp-text ":PROPERTIES:\n:key:\n:END:"	    (forward-line)	    (let ((org-property-format "%-10s %s"))	      (org-indent-line)	      (buffer-string))))))(ert-deftest test-org/indent-region ()  "Test `org-indent-region' specifications."  ;; Indent paragraph.  (should   (equal "A\nB\nC"	  (org-test-with-temp-text " A\nB\n  C"	    (org-indent-region (point-min) (point-max))	    (buffer-string))))  ;; Indent greater elements along with their contents.  (should   (equal "#+BEGIN_CENTER\nA\nB\n#+END_CENTER"	  (org-test-with-temp-text "#+BEGIN_CENTER\n A\n  B\n#+END_CENTER"	    (org-indent-region (point-min) (point-max))	    (buffer-string))))  ;; Ignore contents of verse blocks and example blocks.  (should   (equal "#+BEGIN_VERSE\n A\n  B\n#+END_VERSE"	  (org-test-with-temp-text "#+BEGIN_VERSE\n A\n  B\n#+END_VERSE"	    (org-indent-region (point-min) (point-max))	    (buffer-string))))  (should   (equal "#+BEGIN_EXAMPLE\n A\n  B\n#+END_EXAMPLE"	  (org-test-with-temp-text "#+BEGIN_EXAMPLE\n A\n  B\n#+END_EXAMPLE"	    (org-indent-region (point-min) (point-max))	    (buffer-string))))  ;; Indent according to mode if `org-src-tab-acts-natively' is  ;; non-nil.  Otherwise, do not indent code at all.  (should   (equal "#+BEGIN_SRC emacs-lisp\n(and A\n     B)\n#+END_SRC"	  (org-test-with-temp-text	      "#+BEGIN_SRC emacs-lisp\n (and A\nB)\n#+END_SRC"	    (let ((org-src-tab-acts-natively t)		  (org-edit-src-content-indentation 0))	      (org-indent-region (point-min) (point-max)))	    (buffer-string))))  (should   (equal "#+BEGIN_SRC emacs-lisp\n (and A\nB)\n#+END_SRC"	  (org-test-with-temp-text	      "#+BEGIN_SRC emacs-lisp\n (and A\nB)\n#+END_SRC"	    (let ((org-src-tab-acts-natively nil)		  (org-edit-src-content-indentation 0))	      (org-indent-region (point-min) (point-max)))	    (buffer-string))))  ;; Align node properties according to `org-property-format'.  Handle  ;; nicely empty values.  (should   (equal ":PROPERTIES:\n:key:      value\n:END:"	  (org-test-with-temp-text ":PROPERTIES:\n:key: value\n:END:"	    (let ((org-property-format "%-10s %s"))	      (org-indent-region (point-min) (point-max)))	    (buffer-string))))  (should   (equal ":PROPERTIES:\n:key:\n:END:"	  (org-test-with-temp-text ":PROPERTIES:\n:key:\n:END:"	    (let ((org-property-format "%-10s %s"))	      (org-indent-region (point-min) (point-max)))	    (buffer-string))))  ;; Special case: plain lists and footnote definitions.  (should   (equal "- A\n  B\n  - C\n\n    D"	  (org-test-with-temp-text "- A\n   B\n  - C\n\n     D"	    (org-indent-region (point-min) (point-max))	    (buffer-string))))  (should   (equal "[fn:1] Definition\n\nDefinition"	  (org-test-with-temp-text "[fn:1] Definition\n\n  Definition"	    (org-indent-region (point-min) (point-max))	    (buffer-string)))));;; Editing;;;; Insert elements(ert-deftest test-org/meta-return ()  "Test M-RET (`org-meta-return')."  ;; In a table field insert a row above.  (should   (org-test-with-temp-text "| a |"     (forward-char)     (org-meta-return)     (forward-line -1)     (looking-at "|   |$")))  ;; In a paragraph change current line into a header.  (should   (org-test-with-temp-text "a"     (org-meta-return)     (beginning-of-line)     (looking-at "\* a$")))  ;; In an item insert an item, in this case above.  (should   (org-test-with-temp-text "- a"     (org-meta-return)     (beginning-of-line)     (looking-at "- $")))  ;; In a drawer and paragraph insert an empty line, in this case above.  (should   (org-test-with-temp-text ":MYDRAWER:\na\n:END:"     (forward-line)     (org-meta-return)     (forward-line -1)     (looking-at "$")))  ;; In a drawer and item insert an item, in this case above.  (should   (org-test-with-temp-text ":MYDRAWER:\n- a\n:END:"     (forward-line)     (org-meta-return)     (beginning-of-line)     (looking-at "- $"))))(ert-deftest test-org/insert-todo-heading-respect-content ()  "Test `org-insert-todo-heading-respect-content' specifications."  ;; Create a TODO heading.  (should   (org-test-with-temp-text "* H1\n Body"     (org-insert-todo-heading-respect-content)     (nth 2 (org-heading-components))))  ;; Add headline at the end of the first subtree  (should   (org-test-with-temp-text "* H1\nH1Body\n** H2\nH2Body"     (search-forward "H1Body")     (org-insert-todo-heading-respect-content)     (and (eobp) (org-at-heading-p))))  ;; In a list, do not create a new item.  (should   (org-test-with-temp-text "* H\n- an item\n- another one"     (search-forward "an ")     (org-insert-todo-heading-respect-content)     (and (eobp) (org-at-heading-p)))));;; Fixed-Width Areas(ert-deftest test-org/toggle-fixed-width ()  "Test `org-toggle-fixed-width' specifications."  ;; No region: Toggle on fixed-width marker in paragraphs.  (should   (equal ": A"	  (org-test-with-temp-text "A"	    (org-toggle-fixed-width)	    (buffer-string))))  ;; No region: Toggle off fixed-width markers in fixed-width areas.  (should   (equal "A"	  (org-test-with-temp-text ": A"	    (org-toggle-fixed-width)	    (buffer-string))))  ;; No region: Toggle on marker in blank lines after elements or just  ;; after a headline.  (should   (equal "* H\n: "	  (org-test-with-temp-text "* H\n"	    (forward-line)	    (org-toggle-fixed-width)	    (buffer-string))))  (should   (equal "#+BEGIN_EXAMPLE\nContents\n#+END_EXAMPLE\n: "	  (org-test-with-temp-text "#+BEGIN_EXAMPLE\nContents\n#+END_EXAMPLE\n"	    (goto-char (point-max))	    (org-toggle-fixed-width)	    (buffer-string))))  ;; No region: Toggle on marker in front of one line elements (e.g.,  ;; headlines, clocks)  (should   (equal ": * Headline"	  (org-test-with-temp-text "* Headline"	    (org-toggle-fixed-width)	    (buffer-string))))  (should   (equal ": #+KEYWORD: value"	  (org-test-with-temp-text "#+KEYWORD: value"	    (org-toggle-fixed-width)	    (buffer-string))))  ;; No region: error in other situations.  (should-error   (org-test-with-temp-text "#+BEGIN_EXAMPLE\n: A\n#+END_EXAMPLE"     (forward-line)     (org-toggle-fixed-width)     (buffer-string)))  ;; No region: Indentation is preserved.  (should   (equal "- A\n  : B"	  (org-test-with-temp-text "- A\n  B"	    (forward-line)	    (org-toggle-fixed-width)	    (buffer-string))))  ;; Region: If it contains only fixed-width elements and blank lines,  ;; toggle off fixed-width markup.  (should   (equal "A\n\nB"	  (org-test-with-temp-text ": A\n\n: B"	    (transient-mark-mode 1)	    (push-mark (point) t t)	    (goto-char (point-max))	    (org-toggle-fixed-width)	    (buffer-string))))  ;; Region: If it contains anything else, toggle on fixed-width but  ;; not on fixed-width areas.  (should   (equal ": A\n: \n: B\n: \n: C"	  (org-test-with-temp-text "A\n\n: B\n\nC"	    (transient-mark-mode 1)	    (push-mark (point) t t)	    (goto-char (point-max))	    (org-toggle-fixed-width)	    (buffer-string))))  ;; Region: Ignore blank lines at its end, unless it contains only  ;; such lines.  (should   (equal ": A\n\n"	  (org-test-with-temp-text "A\n\n"	    (transient-mark-mode 1)	    (push-mark (point) t t)	    (goto-char (point-max))	    (org-toggle-fixed-width)	    (buffer-string))))  (should   (equal ": \n: \n"	  (org-test-with-temp-text "\n\n"	    (transient-mark-mode 1)	    (push-mark (point) t t)	    (goto-char (point-max))	    (org-toggle-fixed-width)	    (buffer-string)))));;; Headline(ert-deftest test-org/in-commented-heading-p ()  "Test `org-in-commented-heading-p' specifications."  ;; Commented headline.  (should   (org-test-with-temp-text "* COMMENT Headline\nBody"     (goto-char (point-max))     (org-in-commented-heading-p)))  ;; Commented ancestor.  (should   (org-test-with-temp-text "* COMMENT Headline\n** Level 2\nBody"     (goto-char (point-max))     (org-in-commented-heading-p)))  ;; Comment keyword is case-sensitive.  (should-not   (org-test-with-temp-text "* Comment Headline\nBody"     (goto-char (point-max))     (org-in-commented-heading-p)))  ;; Keyword is standalone.  (should-not   (org-test-with-temp-text "* COMMENTHeadline\nBody"     (goto-char (point-max))     (org-in-commented-heading-p)))  ;; Optional argument.  (should-not   (org-test-with-temp-text "* COMMENT Headline\n** Level 2\nBody"     (goto-char (point-max))     (org-in-commented-heading-p t))));;; Links;;;; Coderefs(ert-deftest test-org/coderef ()  "Test coderef links specifications."  (should   (org-test-with-temp-text "#+BEGIN_SRC emacs-lisp\(+ 1 1)                  (ref:sc)#+END_SRC\[[(sc)]]"     (goto-char (point-max))     (org-open-at-point)     (looking-at "(ref:sc)"))));;;; Custom ID(ert-deftest test-org/custom-id ()  "Test custom ID links specifications."  (should   (org-test-with-temp-text       "* H1\n:PROPERTIES:\n:CUSTOM_ID: custom\n:END:\n* H2\n[[#custom]]"     (goto-char (point-max))     (org-open-at-point)     (org-looking-at-p "\\* H1"))));;;; Fuzzy Links;; Fuzzy links [[text]] encompass links to a target (<<text>>), to;; a named element (#+name: text) and to headlines (* Text).(ert-deftest test-org/fuzzy-links ()  "Test fuzzy links specifications."  ;; Fuzzy link goes in priority to a matching target.  (should   (org-test-with-temp-text "#+NAME: Test\n|a|b|\n<<Test>>\n* Test\n[[Test]]"     (goto-line 5)     (org-open-at-point)     (looking-at "<<Test>>")))  ;; Then fuzzy link points to an element with a given name.  (should   (org-test-with-temp-text "Test\n#+NAME: Test\n|a|b|\n* Test\n[[Test]]"     (goto-line 5)     (org-open-at-point)     (looking-at "#\\+NAME: Test")))  ;; A target still lead to a matching headline otherwise.  (should   (org-test-with-temp-text "* Head1\n* Head2\n*Head3\n[[Head2]]"     (goto-line 4)     (org-open-at-point)     (looking-at "\\* Head2")))  ;; With a leading star in link, enforce heading match.  (should   (org-test-with-temp-text "* Test\n<<Test>>\n[[*Test]]"     (goto-line 3)     (org-open-at-point)     (looking-at "\\* Test")))  ;; Correctly un-hexify fuzzy links.  (should   (org-test-with-temp-text "* With space\n[[*With%20space][With space]]"     (goto-char (point-max))     (org-open-at-point)     (bobp))));;;; Link Escaping(ert-deftest test-org/org-link-escape-ascii-character ()  "Escape an ascii character."  (should   (string=    "%5B"    (org-link-escape "["))))(ert-deftest test-org/org-link-escape-ascii-ctrl-character ()  "Escape an ascii control character."  (should   (string=    "%09"    (org-link-escape "\t"))))(ert-deftest test-org/org-link-escape-multibyte-character ()  "Escape an unicode multibyte character."  (should   (string=    "%E2%82%AC"    (org-link-escape "€"))))(ert-deftest test-org/org-link-escape-custom-table ()  "Escape string with custom character table."  (should   (string=    "Foo%3A%42ar%0A"    (org-link-escape "Foo:Bar\n" '(?\: ?\B)))))(ert-deftest test-org/org-link-escape-custom-table-merge ()  "Escape string with custom table merged with default table."  (should   (string=    "%5BF%6F%6F%3A%42ar%0A%5D"    (org-link-escape "[Foo:Bar\n]" '(?\: ?\B ?\o) t))))(ert-deftest test-org/org-link-unescape-ascii-character ()  "Unescape an ascii character."  (should   (string=    "["    (org-link-unescape "%5B"))))(ert-deftest test-org/org-link-unescape-ascii-ctrl-character ()  "Unescpae an ascii control character."  (should   (string=    "\n"    (org-link-unescape "%0A"))))(ert-deftest test-org/org-link-unescape-multibyte-character ()  "Unescape unicode multibyte character."  (should   (string=    "€"    (org-link-unescape "%E2%82%AC"))))(ert-deftest test-org/org-link-unescape-ascii-extended-char ()  "Unescape old style percent escaped character."  (should   (string=    "àâçèéêîôùû"        (decode-coding-string	 (org-link-unescape "%E0%E2%E7%E8%E9%EA%EE%F4%F9%FB") 'latin-1))))(ert-deftest test-org/org-link-escape-url-with-escaped-char ()  "Escape and unescape a URL that includes an escaped char.http://article.gmane.org/gmane.emacs.orgmode/21459/"  (should   (string=    "http://some.host.com/form?&id=blah%2Bblah25"    (org-link-unescape     (org-link-escape "http://some.host.com/form?&id=blah%2Bblah25")))))(ert-deftest test-org/org-link-escape-chars-browser ()  "Test of the constant `org-link-escape-chars-browser'.See there why this test is a candidate to be removed once Orgdrops support for Emacs 24.1 and 24.2."  (should   (string=    (concat "http://lists.gnu.org/archive/cgi-bin/namazu.cgi?query="	    "%22Release%208.2%22&idxname=emacs-orgmode")    (org-link-escape-browser ; Do not replace with `url-encode-url',			     ; see docstring above.     (concat "http://lists.gnu.org/archive/cgi-bin/namazu.cgi?query="	     "\"Release 8.2\"&idxname=emacs-orgmode")))));;; Node Properties(ert-deftest test-org/accumulated-properties-in-drawers ()  "Ensure properties accumulate in subtree drawers."  (org-test-at-id "75282ba2-f77a-4309-a970-e87c149fe125"    (org-babel-next-src-block)    (should (equal '(2 1) (org-babel-execute-src-block)))));;; Mark Region(ert-deftest test-org/mark-subtree ()  "Test `org-mark-subtree' specifications."  ;; Error when point is before first headline.  (should-error   (org-test-with-temp-text "Paragraph\n* Headline\nBody"     (progn (transient-mark-mode 1)	    (org-mark-subtree))))  ;; Without argument, mark current subtree.  (should   (equal    '(12 32)    (org-test-with-temp-text "* Headline\n** Sub-headline\nBody"      (progn (transient-mark-mode 1)	     (forward-line 2)	     (org-mark-subtree)	     (list (region-beginning) (region-end))))))  ;; With an argument, move ARG up.  (should   (equal    '(1 32)    (org-test-with-temp-text "* Headline\n** Sub-headline\nBody"      (progn (transient-mark-mode 1)	     (forward-line 2)	     (org-mark-subtree 1)	     (list (region-beginning) (region-end))))))  ;; Do not get fooled by inlinetasks.  (when (featurep 'org-inlinetask)    (should     (= 1	(org-test-with-temp-text "* Headline\n*************** Task\nContents"	  (progn (transient-mark-mode 1)		 (forward-line 1)		 (let ((org-inlinetask-min-level 15)) (org-mark-subtree))		 (region-beginning))))))) ;;; Navigation(ert-deftest test-org/beginning-of-line ()  "Test `org-beginning-of-line' specifications."  ;; Standard test.  (should   (org-test-with-temp-text "Some text\nSome other text"     (progn (org-beginning-of-line) (bolp))))  ;; Standard test with `visual-line-mode'.  (should-not   (org-test-with-temp-text "A long line of text\nSome other text"     (progn (visual-line-mode)	    (forward-char 2)	    (dotimes (i 1000) (insert "very "))	    (org-beginning-of-line)	    (bolp))))  ;; At an headline with special movement.  (should   (org-test-with-temp-text "* TODO Headline"     (let ((org-special-ctrl-a/e t))       (org-end-of-line)       (and (progn (org-beginning-of-line) (looking-at "Headline"))	    (progn (org-beginning-of-line) (bolp))	    (progn (org-beginning-of-line) (looking-at "Headline")))))))(ert-deftest test-org/end-of-line ()  "Test `org-end-of-line' specifications."  ;; Standard test.  (should   (org-test-with-temp-text "Some text\nSome other text"     (progn (org-end-of-line) (eolp))))  ;; Standard test with `visual-line-mode'.  (should-not   (org-test-with-temp-text "A long line of text\nSome other text"     (progn (visual-line-mode)	    (forward-char 2)	    (dotimes (i 1000) (insert "very "))	    (goto-char (point-min))	    (org-end-of-line)	    (eolp))))  ;; At an headline with special movement.  (should   (org-test-with-temp-text "* Headline1 :tag:\n"     (let ((org-special-ctrl-a/e t))       (and (progn (org-end-of-line) (looking-at " :tag:"))	    (progn (org-end-of-line) (eolp))	    (progn (org-end-of-line) (looking-at " :tag:"))))))  ;; At an headline without special movement.  (should   (org-test-with-temp-text "* Headline2 :tag:\n"     (let ((org-special-ctrl-a/e nil))       (and (progn (org-end-of-line) (eolp))	    (progn (org-end-of-line) (eolp))))))  ;; At an headline, with reversed movement.  (should   (org-test-with-temp-text "* Headline3 :tag:\n"     (let ((org-special-ctrl-a/e 'reversed)	   (this-command last-command))       (and (progn (org-end-of-line) (eolp))	    (progn (org-end-of-line) (looking-at " :tag:"))))))  ;; At a block without hidden contents.  (should   (org-test-with-temp-text "#+BEGIN_CENTER\nContents\n#+END_CENTER"     (progn (org-end-of-line) (eolp))))  ;; At a block with hidden contents.  (should-not   (org-test-with-temp-text "#+BEGIN_CENTER\nContents\n#+END_CENTER"     (let ((org-special-ctrl-a/e t))       (org-hide-block-toggle)       (org-end-of-line)       (eobp)))))(ert-deftest test-org/forward-paragraph ()  "Test `org-forward-paragraph' specifications."  ;; At end of buffer, return an error.  (should-error   (org-test-with-temp-text "Paragraph"     (goto-char (point-max))     (org-forward-paragraph)))  ;; Standard test.  (should   (org-test-with-temp-text "P1\n\nP2\n\nP3"     (org-forward-paragraph)     (looking-at "P2")))  ;; Ignore depth.  (should   (org-test-with-temp-text "#+BEGIN_CENTER\nP1\n#+END_CENTER\nP2"     (org-forward-paragraph)     (looking-at "P1")))  ;; Do not enter elements with invisible contents.  (should   (org-test-with-temp-text "#+BEGIN_CENTER\nP1\n\nP2\n#+END_CENTER\nP3"     (org-hide-block-toggle)     (org-forward-paragraph)     (looking-at "P3")))  ;; On an affiliated keyword, jump to the beginning of the element.  (should   (org-test-with-temp-text "#+name: para\n#+caption: caption\nPara"     (org-forward-paragraph)     (looking-at "Para")))  ;; On an item or a footnote definition, move to the second element  ;; inside, if any.  (should   (org-test-with-temp-text "- Item1\n\n  Paragraph\n- Item2"     (org-forward-paragraph)     (looking-at "  Paragraph")))  (should   (org-test-with-temp-text "[fn:1] Def1\n\nParagraph\n\n[fn:2] Def2"     (org-forward-paragraph)     (looking-at "Paragraph")))  ;; On an item, or a footnote definition, when the first line is  ;; empty, move to the first item.  (should   (org-test-with-temp-text "- \n\n  Paragraph\n- Item2"     (org-forward-paragraph)     (looking-at "  Paragraph")))  (should   (org-test-with-temp-text "[fn:1]\n\nParagraph\n\n[fn:2] Def2"     (org-forward-paragraph)     (looking-at "Paragraph")))  ;; On a table (resp. a property drawer) do not move through table  ;; rows (resp. node properties).  (should   (org-test-with-temp-text "| a | b |\n| c | d |\nParagraph"     (org-forward-paragraph)     (looking-at "Paragraph")))  (should   (org-test-with-temp-text ":PROPERTIES:\n:prop: value\n:END:\nParagraph"     (org-forward-paragraph)     (looking-at "Paragraph")))  ;; On a verse or source block, stop after blank lines.  (should   (org-test-with-temp-text "#+BEGIN_VERSE\nL1\n\nL2\n#+END_VERSE"     (org-forward-paragraph)     (looking-at "L2")))  (should   (org-test-with-temp-text "#+BEGIN_SRC\nL1\n\nL2\n#+END_SRC"     (org-forward-paragraph)     (looking-at "L2"))))(ert-deftest test-org/backward-paragraph ()  "Test `org-backward-paragraph' specifications."  ;; Error at beginning of buffer.  (should-error   (org-test-with-temp-text "Paragraph"     (org-backward-paragraph)))  ;; Regular test.  (should   (org-test-with-temp-text "P1\n\nP2\n\nP3"     (goto-char (point-max))     (org-backward-paragraph)     (looking-at "P3")))  (should   (org-test-with-temp-text "P1\n\nP2\n\nP3"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (looking-at "P2")))  ;; Ignore depth.  (should   (org-test-with-temp-text "P1\n\n#+BEGIN_CENTER\nP2\n#+END_CENTER\nP3"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (looking-at "P2")))  ;; Ignore invisible elements.  (should   (org-test-with-temp-text "* H1\n  P1\n* H2"     (org-cycle)     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (bobp)))  ;; On an affiliated keyword, jump to the first one.  (should   (org-test-with-temp-text "P1\n#+name: n\n#+caption: c1\n#+caption: c2\nP2"     (search-forward "c2")     (org-backward-paragraph)     (looking-at "#\\+name")))  ;; On the second element in an item or a footnote definition, jump  ;; to item or the definition.  (should   (org-test-with-temp-text "- line1\n\n  line2"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (looking-at "- line1")))  (should   (org-test-with-temp-text "[fn:1] line1\n\n  line2"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (looking-at "\\[fn:1\\] line1")))  ;; On a table (resp. a property drawer), ignore table rows  ;; (resp. node properties).  (should   (org-test-with-temp-text "| a | b |\n| c | d |\nP1"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (bobp)))  (should   (org-test-with-temp-text ":PROPERTIES:\n:prop: value\n:END:\nP1"     (goto-char (point-max))     (beginning-of-line)     (org-backward-paragraph)     (bobp)))  ;; On a source or verse block, stop before blank lines.  (should   (org-test-with-temp-text "#+BEGIN_VERSE\nL1\n\nL2\n\nL3\n#+END_VERSE"     (search-forward "L3")     (beginning-of-line)     (org-backward-paragraph)     (looking-at "L2")))  (should   (org-test-with-temp-text "#+BEGIN_SRC\nL1\n\nL2\n\nL3#+END_SRC"     (search-forward "L3")     (beginning-of-line)     (org-backward-paragraph)     (looking-at "L2"))))(ert-deftest test-org/forward-element ()  "Test `org-forward-element' specifications."  ;; 1. At EOB: should error.  (org-test-with-temp-text "Some text\n"    (goto-char (point-max))    (should-error (org-forward-element)))  ;; 2. Standard move: expected to ignore blank lines.  (org-test-with-temp-text "First paragraph.\n\n\nSecond paragraph."    (org-forward-element)    (should (looking-at (regexp-quote "Second paragraph."))))  ;; 3. Headline tests.  (org-test-with-temp-text "* Head 1** Head 1.1*** Head 1.1.1** Head 1.2"    ;; 3.1. At an headline beginning: move to next headline at the    ;;      same level.    (goto-line 3)    (org-forward-element)    (should (looking-at (regexp-quote "** Head 1.2")))    ;; 3.2. At an headline beginning: move to parent headline if no    ;;      headline at the same level.    (goto-line 3)    (org-forward-element)    (should (looking-at (regexp-quote "** Head 1.2"))))  ;; 4. Greater element tests.  (org-test-with-temp-text      "#+BEGIN_CENTER\nInside.\n#+END_CENTER\n\nOutside."    ;; 4.1. At a greater element: expected to skip contents.    (org-forward-element)    (should (looking-at (regexp-quote "Outside.")))    ;; 4.2. At the end of greater element contents: expected to skip    ;;      to the end of the greater element.    (goto-line 2)    (org-forward-element)    (should (looking-at (regexp-quote "Outside."))))  ;; 5. List tests.  (org-test-with-temp-text "- item1  - sub1  - sub2  - sub3  Inner paragraph.- item2Outside."    ;; 5.1. At list top point: expected to move to the element after    ;;      the list.    (goto-line 2)    (org-forward-element)    (should (looking-at (regexp-quote "Outside.")))    ;; 5.2. Special case: at the first line of a sub-list, but not at    ;;      beginning of line, move to next item.    (goto-line 2)    (forward-char)    (org-forward-element)    (should (looking-at "- item2"))    (goto-line 4)    (forward-char)    (org-forward-element)    (should (looking-at "  - sub2"))    ;; 5.3 At sub-list beginning: expected to move after the sub-list.    (goto-line 4)    (org-forward-element)    (should (looking-at (regexp-quote "  Inner paragraph.")))    ;; 5.4. At sub-list end: expected to move outside the sub-list.    (goto-line 8)    (org-forward-element)    (should (looking-at (regexp-quote "  Inner paragraph.")))    ;; 5.5. At an item: expected to move to next item, if any.    (goto-line 6)    (org-forward-element)    (should (looking-at "  - sub3"))))(ert-deftest test-org/backward-element ()  "Test `org-backward-element' specifications."  ;; 1. Should error at BOB.  (org-test-with-temp-text "    \nParagraph."    (should-error (org-backward-element)))  ;; 2. Should move at BOB when called on the first element in buffer.  (should   (org-test-with-temp-text "\n#+TITLE: test"     (progn (forward-line)	    (org-backward-element)	    (bobp))))  ;; 3. Not at the beginning of an element: move at its beginning.  (org-test-with-temp-text "Paragraph1.\n\nParagraph2."    (goto-line 3)    (end-of-line)    (org-backward-element)    (should (looking-at (regexp-quote "Paragraph2."))))  ;; 4. Headline tests.  (org-test-with-temp-text "* Head 1** Head 1.1*** Head 1.1.1** Head 1.2"    ;; 4.1. At an headline beginning: move to previous headline at the    ;;      same level.    (goto-line 5)    (org-backward-element)    (should (looking-at (regexp-quote "** Head 1.1")))    ;; 4.2. At an headline beginning: move to parent headline if no    ;;      headline at the same level.    (goto-line 3)    (org-backward-element)    (should (looking-at (regexp-quote "* Head 1")))    ;; 4.3. At the first top-level headline: should error.    (goto-line 2)    (should-error (org-backward-element)))  ;; 5. At beginning of first element inside a greater element:  ;;    expected to move to greater element's beginning.  (org-test-with-temp-text "Before.\n#+BEGIN_CENTER\nInside.\n#+END_CENTER"    (goto-line 3)    (org-backward-element)    (should (looking-at "#\\+BEGIN_CENTER")))  ;; 6. At the beginning of the first element in a section: should  ;;    move back to headline, if any.  (should   (org-test-with-temp-text "#+TITLE: test\n* Headline\n\nParagraph"     (progn (goto-char (point-max))	    (beginning-of-line)	    (org-backward-element)	    (org-at-heading-p))))  ;; 7. List tests.  (org-test-with-temp-text "- item1  - sub1  - sub2  - sub3  Inner paragraph.- item2Outside."    ;; 7.1. At beginning of sub-list: expected to move to the    ;;      paragraph before it.    (goto-line 4)    (org-backward-element)    (should (looking-at "item1"))    ;; 7.2. At an item in a list: expected to move at previous item.    (goto-line 8)    (org-backward-element)    (should (looking-at "  - sub2"))    (goto-line 12)    (org-backward-element)    (should (looking-at "- item1"))    ;; 7.3. At end of list/sub-list: expected to move to list/sub-list    ;;      beginning.    (goto-line 10)    (org-backward-element)    (should (looking-at "  - sub1"))    (goto-line 15)    (org-backward-element)    (should (looking-at "- item1"))    ;; 7.4. At blank-lines before list end: expected to move to top    ;; item.    (goto-line 14)    (org-backward-element)    (should (looking-at "- item1"))))(ert-deftest test-org/up-element ()  "Test `org-up-element' specifications."  ;; 1. At BOB or with no surrounding element: should error.  (org-test-with-temp-text "Paragraph."    (should-error (org-up-element)))  (org-test-with-temp-text "* Head1\n* Head2"    (goto-line 2)    (should-error (org-up-element)))  (org-test-with-temp-text "Paragraph1.\n\nParagraph2."    (goto-line 3)    (should-error (org-up-element)))  ;; 2. At an headline: move to parent headline.  (org-test-with-temp-text "* Head1\n** Sub-Head1\n** Sub-Head2"    (goto-line 3)    (org-up-element)    (should (looking-at "\\* Head1")))  ;; 3. Inside a greater element: move to greater element beginning.  (org-test-with-temp-text      "Before.\n#+BEGIN_CENTER\nParagraph1\nParagraph2\n#+END_CENTER\n"    (goto-line 3)    (org-up-element)    (should (looking-at "#\\+BEGIN_CENTER")))  ;; 4. List tests.  (org-test-with-temp-text "* Top- item1  - sub1  - sub2    Paragraph within sub2.- item2"    ;; 4.1. Within an item: move to the item beginning.    (goto-line 8)    (org-up-element)    (should (looking-at "  - sub2"))    ;; 4.2. At an item in a sub-list: move to parent item.    (goto-line 4)    (org-up-element)    (should (looking-at "- item1"))    ;; 4.3. At an item in top list: move to beginning of whole list.    (goto-line 10)    (org-up-element)    (should (looking-at "- item1"))    ;; 4.4. Special case.  At very top point: should move to parent of    ;;      list.    (goto-line 2)    (org-up-element)    (should (looking-at "\\* Top"))))(ert-deftest test-org/down-element ()  "Test `org-down-element' specifications."  ;; Error when the element hasn't got a recursive type.  (org-test-with-temp-text "Paragraph."    (should-error (org-down-element)))  ;; Error when the element has no contents  (org-test-with-temp-text "* Headline"    (should-error (org-down-element)))  ;; When at a plain-list, move to first item.  (org-test-with-temp-text "- Item 1\n  - Item 1.1\n  - Item 2.2"    (goto-line 2)    (org-down-element)    (should (looking-at " - Item 1.1")))  (org-test-with-temp-text "#+NAME: list\n- Item 1"    (org-down-element)    (should (looking-at " Item 1")))  ;; When at a table, move to first row  (org-test-with-temp-text "#+NAME: table\n| a | b |"    (org-down-element)    (should (looking-at " a | b |")))  ;; Otherwise, move inside the greater element.  (org-test-with-temp-text "#+BEGIN_CENTER\nParagraph.\n#+END_CENTER"    (org-down-element)    (should (looking-at "Paragraph"))))(ert-deftest test-org/drag-element-backward ()  "Test `org-drag-element-backward' specifications."  ;; 1. Error when trying to move first element of buffer.  (org-test-with-temp-text "Paragraph 1.\n\nParagraph 2."    (should-error (org-drag-element-backward)))  ;; 2. Error when trying to swap nested elements.  (org-test-with-temp-text "#+BEGIN_CENTER\nTest.\n#+END_CENTER"    (forward-line)    (should-error (org-drag-element-backward)))  ;; 3. Error when trying to swap an headline element and  ;;    a non-headline element.  (org-test-with-temp-text "Test.\n* Head 1"    (forward-line)    (should-error (org-drag-element-backward)))  ;; 4. Otherwise, swap elements, preserving column and blank lines  ;;    between elements.  (org-test-with-temp-text "Para1\n\n\nParagraph 2\n\nPara3"    (search-forward "graph")    (org-drag-element-backward)    (should (equal (buffer-string) "Paragraph 2\n\n\nPara1\n\nPara3"))    (should (looking-at " 2")))  ;; 5. Preserve visibility of elements and their contents.  (org-test-with-temp-text "#+BEGIN_CENTERText.#+END_CENTER- item 1  #+BEGIN_QUOTE  Text.  #+END_QUOTE"    (while (search-forward "BEGIN_" nil t) (org-cycle))    (search-backward "- item 1")    (org-drag-element-backward)    (should     (equal      '((63 . 82) (26 . 48))      (mapcar (lambda (ov) (cons (overlay-start ov) (overlay-end ov)))	      (overlays-in (point-min) (point-max)))))))(ert-deftest test-org/drag-element-forward ()  "Test `org-drag-element-forward' specifications."  ;; 1. Error when trying to move first element of buffer.  (org-test-with-temp-text "Paragraph 1.\n\nParagraph 2."    (goto-line 3)    (should-error (org-drag-element-forward)))  ;; 2. Error when trying to swap nested elements.  (org-test-with-temp-text "#+BEGIN_CENTER\nTest.\n#+END_CENTER"    (forward-line)    (should-error (org-drag-element-forward)))  ;; 3. Error when trying to swap a non-headline element and an  ;;    headline.  (org-test-with-temp-text "Test.\n* Head 1"    (should-error (org-drag-element-forward)))  ;; 4. Otherwise, swap elements, preserving column and blank lines  ;;    between elements.  (org-test-with-temp-text "Paragraph 1\n\n\nPara2\n\nPara3"    (search-forward "graph")    (org-drag-element-forward)    (should (equal (buffer-string) "Para2\n\n\nParagraph 1\n\nPara3"))    (should (looking-at " 1")))  ;; 5. Preserve visibility of elements and their contents.  (org-test-with-temp-text "#+BEGIN_CENTERText.#+END_CENTER- item 1  #+BEGIN_QUOTE  Text.  #+END_QUOTE"    (while (search-forward "BEGIN_" nil t) (org-cycle))    (search-backward "#+BEGIN_CENTER")    (org-drag-element-forward)    (should     (equal      '((63 . 82) (26 . 48))      (mapcar (lambda (ov) (cons (overlay-start ov) (overlay-end ov)))	      (overlays-in (point-min) (point-max)))))));;; Planning(ert-deftest test-org/timestamp-has-time-p ()  "Test `org-timestamp-has-time-p' specifications."  ;; With time.  (should   (org-test-with-temp-text "<2012-03-29 Thu 16:40>"     (org-timestamp-has-time-p (org-element-context))))  ;; Without time.  (should-not   (org-test-with-temp-text "<2012-03-29 Thu>"     (org-timestamp-has-time-p (org-element-context)))))(ert-deftest test-org/timestamp-format ()  "Test `org-timestamp-format' specifications."  ;; Regular test.  (should   (equal    "2012-03-29 16:40"    (org-test-with-temp-text "<2012-03-29 Thu 16:40>"      (org-timestamp-format (org-element-context) "%Y-%m-%d %R"))))  ;; Range end.  (should   (equal    "2012-03-29"    (org-test-with-temp-text "[2011-07-14 Thu]--[2012-03-29 Thu]"      (org-timestamp-format (org-element-context) "%Y-%m-%d" t)))))(ert-deftest test-org/timestamp-split-range ()  "Test `org-timestamp-split-range' specifications."  ;; Extract range start (active).  (should   (equal '(2012 3 29)	  (org-test-with-temp-text "<2012-03-29 Thu>--<2012-03-30 Fri>"	    (let ((ts (org-timestamp-split-range (org-element-context))))	      (mapcar (lambda (p) (org-element-property p ts))		      '(:year-end :month-end :day-end))))))  ;; Extract range start (inactive)  (should   (equal '(2012 3 29)	  (org-test-with-temp-text "[2012-03-29 Thu]--[2012-03-30 Fri]"	    (let ((ts (org-timestamp-split-range (org-element-context))))	      (mapcar (lambda (p) (org-element-property p ts))		      '(:year-end :month-end :day-end))))))  ;; Extract range end (active).  (should   (equal '(2012 3 30)	  (org-test-with-temp-text "<2012-03-29 Thu>--<2012-03-30 Fri>"	    (let ((ts (org-timestamp-split-range		       (org-element-context) t)))	      (mapcar (lambda (p) (org-element-property p ts))		      '(:year-end :month-end :day-end))))))  ;; Extract range end (inactive)  (should   (equal '(2012 3 30)	  (org-test-with-temp-text "[2012-03-29 Thu]--[2012-03-30 Fri]"	    (let ((ts (org-timestamp-split-range		       (org-element-context) t)))	      (mapcar (lambda (p) (org-element-property p ts))		      '(:year-end :month-end :day-end))))))  ;; Return the timestamp if not a range.  (should   (org-test-with-temp-text "[2012-03-29 Thu]"     (let* ((ts-orig (org-element-context))	    (ts-copy (org-timestamp-split-range ts-orig)))       (eq ts-orig ts-copy))))  (should   (org-test-with-temp-text "<%%(org-float t 4 2)>"     (let* ((ts-orig (org-element-context))	    (ts-copy (org-timestamp-split-range ts-orig)))       (eq ts-orig ts-copy))))  ;; Check that parent is the same when a range was split.  (should   (org-test-with-temp-text "[2012-03-29 Thu]--[2012-03-30 Fri]"     (let* ((ts-orig (org-element-context))	    (ts-copy (org-timestamp-split-range ts-orig)))       (eq (org-element-property :parent ts-orig)	   (org-element-property :parent ts-copy))))))(ert-deftest test-org/timestamp-translate ()  "Test `org-timestamp-translate' specifications."  ;; Translate whole date range.  (should   (equal "<29>--<30>"	  (org-test-with-temp-text "<2012-03-29 Thu>--<2012-03-30 Fri>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%d>")))	      (org-timestamp-translate (org-element-context))))))  ;; Translate date range start.  (should   (equal "<29>"	  (org-test-with-temp-text "<2012-03-29 Thu>--<2012-03-30 Fri>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%d>")))	      (org-timestamp-translate (org-element-context) 'start)))))  ;; Translate date range end.  (should   (equal "<30>"	  (org-test-with-temp-text "<2012-03-29 Thu>--<2012-03-30 Fri>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%d>")))	      (org-timestamp-translate (org-element-context) 'end)))))  ;; Translate time range.  (should   (equal "<08>--<16>"	  (org-test-with-temp-text "<2012-03-29 Thu 8:30-16:40>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%H>")))	      (org-timestamp-translate (org-element-context))))))  ;; Translate non-range timestamp.  (should   (equal "<29>"	  (org-test-with-temp-text "<2012-03-29 Thu>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%d>")))	      (org-timestamp-translate (org-element-context))))))  ;; Do not change `diary' timestamps.  (should   (equal "<%%(org-float t 4 2)>"	  (org-test-with-temp-text "<%%(org-float t 4 2)>"	    (let ((org-display-custom-times t)		  (org-time-stamp-custom-formats '("<%d>" . "<%d>")))	      (org-timestamp-translate (org-element-context)))))));;; Radio Targets(ert-deftest test-org/update-radio-target-regexp ()  "Test `org-update-radio-target-regexp' specifications."  ;; Properly update cache with no previous radio target regexp.  (should   (eq 'link       (org-test-with-temp-text "radio\n\nParagraph\n\nradio"	 (save-excursion (goto-char (point-max)) (org-element-context))	 (insert "<<<")	 (search-forward "o")	 (insert ">>>")	 (org-update-radio-target-regexp)	 (goto-char (point-max))	 (org-element-type (org-element-context)))))  ;; Properly update cache with previous radio target regexp.  (should   (eq 'link       (org-test-with-temp-text "radio\n\nParagraph\n\nradio"	 (save-excursion (goto-char (point-max)) (org-element-context))	 (insert "<<<")	 (search-forward "o")	 (insert ">>>")	 (org-update-radio-target-regexp)	 (search-backward "r")	 (delete-char 5)	 (insert "new")	 (org-update-radio-target-regexp)	 (goto-char (point-max))	 (delete-region (line-beginning-position) (point))	 (insert "new")	 (org-element-type (org-element-context))))));;; Visibility(ert-deftest test-org/flag-drawer ()  "Test `org-flag-drawer' specifications."  ;; Hide drawer.  (should   (org-test-with-temp-text ":DRAWER:\ncontents\n:END:"     (org-flag-drawer t)     (get-char-property (line-end-position) 'invisible)))  ;; Show drawer.  (should-not   (org-test-with-temp-text ":DRAWER:\ncontents\n:END:"     (org-flag-drawer t)     (org-flag-drawer nil)     (get-char-property (line-end-position) 'invisible)))  ;; Test optional argument.  (should   (org-test-with-temp-text ":D1:\nc1\n:END:\n\n:D2:\nc2\n:END:"     (let ((drawer (save-excursion (search-forward ":D2")				   (org-element-at-point))))       (org-flag-drawer t drawer)       (get-char-property (progn (search-forward ":D2") (line-end-position))			  'invisible))))  (should-not   (org-test-with-temp-text ":D1:\nc1\n:END:\n\n:D2:\nc2\n:END:"     (let ((drawer (save-excursion (search-forward ":D2")				   (org-element-at-point))))       (org-flag-drawer t drawer)       (get-char-property (line-end-position) 'invisible))))  ;; Do not hide fake drawers.  (should-not   (org-test-with-temp-text "#+begin_example\n:D:\nc\n:END:\n#+end_example"     (forward-line 1)     (org-flag-drawer t)     (get-char-property (line-end-position) 'invisible)))  ;; Do not hide incomplete drawers.  (should-not   (org-test-with-temp-text ":D:\nparagraph"     (forward-line 1)     (org-flag-drawer t)     (get-char-property (line-end-position) 'invisible)))  ;; Do not hide drawers when called from final blank lines.  (should-not   (org-test-with-temp-text ":DRAWER:\nA\n:END:\n\n"     (goto-char (point-max))     (org-flag-drawer t)     (goto-char (point-min))     (get-char-property (line-end-position) 'invisible)))  ;; Don't leave point in an invisible part of the buffer when hiding  ;; a drawer away.  (should-not   (org-test-with-temp-text ":DRAWER:\ncontents\n:END:"     (goto-char (point-max))     (org-flag-drawer t)     (get-char-property (point) 'invisible))))(provide 'test-org);;; test-org.el ends here
 |