MDL-67547 dataformat_pdf: method to convert images to supported format.
[moodle.git] / dataformat / pdf / tests / writer_test.php
1 <?php
2 // This file is part of Moodle - http://moodle.org/
3 //
4 // Moodle is free software: you can redistribute it and/or modify
5 // it under the terms of the GNU General Public License as published by
6 // the Free Software Foundation, either version 3 of the License, or
7 // (at your option) any later version.
8 //
9 // Moodle is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //
14 // You should have received a copy of the GNU General Public License
15 // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
17 /**
18  * Tests for the dataformat_pdf writer
19  *
20  * @package    dataformat_pdf
21  * @copyright  2020 Paul Holden <paulh@moodle.com>
22  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
23  */
25 namespace dataformat_pdf;
27 use core\dataformat;
28 use context_system;
29 use html_writer;
30 use moodle_url;
32 /**
33  * Writer tests
34  *
35  * @package    dataformat_pdf
36  * @copyright  2020 Paul Holden <paulh@moodle.com>
37  * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
38  */
39 class writer_testcase extends \advanced_testcase {
41     /**
42      * Test writing data whose content contains an image with pluginfile.php source
43      */
44     public function test_write_data_with_pluginfile_image(): void {
45         global $CFG;
47         $this->resetAfterTest(true);
49         $imagefixture = "{$CFG->dirroot}/lib/filestorage/tests/fixtures/testimage.jpg";
50         $image = get_file_storage()->create_file_from_pathname([
51             'contextid' => context_system::instance()->id,
52             'component' => 'dataformat_pdf',
53             'filearea'  => 'test',
54             'itemid'    => 0,
55             'filepath'  => '/',
56             'filename'  => basename($imagefixture),
58         ], $imagefixture);
60         $imageurl = moodle_url::make_pluginfile_url($image->get_contextid(), $image->get_component(), $image->get_filearea(),
61             $image->get_itemid(), $image->get_filepath(), $image->get_filename());
63         // Insert out test image into the data so it is exported.
64         $columns = ['animal', 'image'];
65         $row = ['cat', html_writer::img($imageurl->out(), 'My image')];
67         // Export to file. Assert that the exported file exists.
68         $exportfile = dataformat::write_data('My export', 'pdf', $columns, [$row]);
69         $this->assertFileExists($exportfile);
71         // The exported file should be a reasonable size (~275kb).
72         $this->assertGreaterThan(270000, filesize($exportfile));
73     }
74 }