You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardexpand all lines: _sources/development.rst.txt
+7-2
Original file line number
Diff line number
Diff line change
@@ -197,8 +197,13 @@ Adding a new program version
197
197
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
198
198
199
199
There are a few conventions when adding a new supported program version to the unit tests:
200
+
200
201
* Two different recent versions are typically used in the unit tests. If there already are two, move the older version(s) the regression suite (see below).
201
-
* When adding files for the new version, first copy the corresponding files for the last version already in cclib. Afterwards, check in files from the new program version as changes to the copied files. This procedure makes it easy to look at the differences introduced with the new version in git clients.
202
+
* When adding files for the new version:
203
+
204
+
#. Make a commit that copies the corresponding files from the last version already in cclib to the new directory.
205
+
#. Make a commit that replaces these files with those for the actual new version. This procedure makes it easy to look at the differences introduced with the new version in git clients.
206
+
#. See https://github.com/cclib/cclib/pull/575/commits for an example.
202
207
203
208
.. index::
204
209
single: testing; regressions
@@ -221,7 +226,7 @@ Using both the unit and regression tests, the line-by-line `test coverage`_ show
221
226
Adding a new regression test
222
227
^^^^^^^^^^^^^^^^^^^^^^^^^^^^
223
228
224
-
A regression test consists of one or more output files and optionally a test function or class.
229
+
A regression test consists of one or more output files and optionally a test function and/or multiple test classes.
225
230
226
231
New regression tests are added by creating entries in `regressionfiles.yaml`_. There are three kinds of tests:
The source code of the newest release of cclib (version |release|) is distributed as:
91
-
* A .zip file: https://github.com/cclib/cclib/releases/download/v1.8.1/cclib-1.8.1.zip
92
-
* A .tar.gz file: https://github.com/cclib/cclib/releases/download/v1.8.1/cclib-1.8.1.tar.gz
93
-
* Windows binary installers (see the `newest release page`_)
91
+
92
+
* A .zip file: https://github.com/cclib/cclib/releases/download/v1.8.1/cclib-1.8.1.zip
93
+
* A .tar.gz file: https://github.com/cclib/cclib/releases/download/v1.8.1/cclib-1.8.1.tar.gz
94
+
* Windows binary installers (see the `newest release page`_)
94
95
95
96
On Windows, if you choose to download the .exe files instead, you can install simply by double-clicking on the file. To uninstall, use the "Add and Remove Programs" menu in the Control Panel.
Copy file name to clipboardexpand all lines: development.html
+12-4
Original file line number
Diff line number
Diff line change
@@ -239,9 +239,17 @@ <h4>Adding a new unit test<a class="headerlink" href="#adding-a-new-unit-test" t
239
239
</section>
240
240
<sectionid="adding-a-new-program-version">
241
241
<h4>Adding a new program version<aclass="headerlink" href="#adding-a-new-program-version" title="Link to this heading"></a></h4>
242
-
<p>There are a few conventions when adding a new supported program version to the unit tests:
243
-
* Two different recent versions are typically used in the unit tests. If there already are two, move the older version(s) the regression suite (see below).
244
-
* When adding files for the new version, first copy the corresponding files for the last version already in cclib. Afterwards, check in files from the new program version as changes to the copied files. This procedure makes it easy to look at the differences introduced with the new version in git clients.</p>
242
+
<p>There are a few conventions when adding a new supported program version to the unit tests:</p>
243
+
<ulclass="simple">
244
+
<li><p>Two different recent versions are typically used in the unit tests. If there already are two, move the older version(s) the regression suite (see below).</p></li>
245
+
<li><p>When adding files for the new version:</p>
246
+
<olclass="arabic simple">
247
+
<li><p>Make a commit that copies the corresponding files from the last version already in cclib to the new directory.</p></li>
248
+
<li><p>Make a commit that replaces these files with those for the actual new version. This procedure makes it easy to look at the differences introduced with the new version in git clients.</p></li>
249
+
<li><p>See <aclass="reference external" href="https://github.com/cclib/cclib/pull/575/commits">https://github.com/cclib/cclib/pull/575/commits</a> for an example.</p></li>
250
+
</ol>
251
+
</li>
252
+
</ul>
245
253
</section>
246
254
</section>
247
255
<sectionid="regression-tests">
@@ -251,7 +259,7 @@ <h4>Adding a new program version<a class="headerlink" href="#adding-a-new-progra
251
259
<p>Using both the unit and regression tests, the line-by-line <aclass="reference external" href="coverage/index.html">test coverage</a> shows which parts of cclib are touched by at least one test. When adding new features and tests, the GitHub Actions <aclass="reference external" href="https://github.com/cclib/cclib/blob/master/.github/scripts/run_pytest.bash">testing script</a> can be run locally to generate the HTML coverage pages and ensure that the tests exercise the feature code.</p>
252
260
<sectionid="adding-a-new-regression-test">
253
261
<h4>Adding a new regression test<aclass="headerlink" href="#adding-a-new-regression-test" title="Link to this heading"></a></h4>
254
-
<p>A regression test consists of one or more output files and optionally a test function or class.</p>
262
+
<p>A regression test consists of one or more output files and optionally a test function and/or multiple test classes.</p>
255
263
<p>New regression tests are added by creating entries in <aclass="reference external" href="https://github.com/cclib/cclib-data/blob/master/regressionfiles.yaml">regressionfiles.yaml</a>. There are three kinds of tests:</p>
256
264
<ulclass="simple">
257
265
<li><p>A regression may be parsed, but specific attributes on the regression are not checked: no test function or class is added.</p></li>
<p>There are in fact multiple packages, <aclass="reference external" href="https://packages.debian.org/bullseye/python3-cclib">python3-cclib</a> containing the Python module, and <aclass="reference external" href="https://packages.debian.org/bullseye/cclib">cclib</a> which installs the user scripts and depends on the Python module. If you also need to also install the unittests and logfiles we distribute, you will need to install the <aclass="reference external" href="https://packages.debian.org/bullseye/cclib-data">cclib-data</a> package from the non-free repositories (due to license issues). Because of distribution release cycles, package manager versions of cclib may be out of date compared to the PyPI version.</p>
153
+
<p>There are in fact multiple packages, <aclass="reference external" href="https://packages.debian.org/bookworm/python3-cclib">python3-cclib</a> containing the Python module, and <aclass="reference external" href="https://packages.debian.org/bookworm/cclib">cclib</a> which installs the user scripts and depends on the Python module. If you also need to also install the unittests and logfiles we distribute, you will need to install the <aclass="reference external" href="https://packages.debian.org/bookworm/cclib-data">cclib-data</a> package from the non-free repositories (due to license issues). Because of distribution release cycles, package manager versions of cclib may be out of date compared to the PyPI version.</p>
154
154
</section>
155
155
<sectionid="manual-download-and-install">
156
156
<h2>Manual download and install<aclass="headerlink" href="#manual-download-and-install" title="Link to this heading"></a></h2>
157
-
<dlclass="simple">
158
-
<dt>The source code of the newest release of cclib (version 1.8.1) is distributed as:</dt><dd><ulclass="simple">
157
+
<p>The source code of the newest release of cclib (version 1.8.1) is distributed as:</p>
<li><p>Windows binary installers (see the <aclass="reference external" href="https://github.com/cclib/cclib/releases/tag/v1.8.1">newest release page</a>)</p></li>
162
162
</ul>
163
-
</dd>
164
-
</dl>
165
163
<p>On Windows, if you choose to download the .exe files instead, you can install simply by double-clicking on the file. To uninstall, use the “Add and Remove Programs” menu in the Control Panel.</p>
166
164
<p>None of these files include the tests and logfiles used for testing. In order to download all tests, we also provide source archives on the <aclass="reference external" href="https://github.com/cclib/cclib/releases/tag/v1.8.1">newest release page</a>.</p>
167
165
<p>If you are using the .zip or .tar.gz files, extract the contents of the file at an appropriate location, which we will call INSTALLDIR. Open a command prompt and change directory to INSTALLDIR. Next, run the following commands to install cclib:</p>
0 commit comments