blob: fd48840d285444e94dd4a1f0993ad7267fc0301e [file] [log] [blame]
Lei Zhang1ac47eb2015-12-21 11:04:44 -08001// Copyright 2015 PDFium Authors. All rights reserved.
Tom Sepez96d13342015-01-16 14:59:26 -08002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
5#ifndef TESTING_EMBEDDER_TEST_H_
6#define TESTING_EMBEDDER_TEST_H_
7
Tom Sepez396e8722015-09-09 10:16:08 -07008#include <map>
Lei Zhangaa8bf7e2015-12-24 19:13:32 -08009#include <memory>
Tom Sepez96d13342015-01-16 14:59:26 -080010#include <string>
11
Lei Zhangb4e7f302015-11-06 15:52:32 -080012#include "public/fpdf_dataavail.h"
13#include "public/fpdf_ext.h"
14#include "public/fpdf_formfill.h"
15#include "public/fpdfview.h"
Tom Sepez96d13342015-01-16 14:59:26 -080016#include "testing/gtest/include/gtest/gtest.h"
Tom Sepez0aa35312016-01-06 10:16:32 -080017#include "testing/test_support.h"
Tom Sepez452b4f32015-10-13 09:27:27 -070018
19#ifdef PDF_ENABLE_V8
Tom Sepez96d13342015-01-16 14:59:26 -080020#include "v8/include/v8.h"
Tom Sepez452b4f32015-10-13 09:27:27 -070021#endif // PDF_ENABLE_v8
Tom Sepez96d13342015-01-16 14:59:26 -080022
23class TestLoader;
24
25// This class is used to load a PDF document, and then run programatic
26// API tests against it.
Tom Sepez4cb0fa72015-02-25 16:08:18 -080027class EmbedderTest : public ::testing::Test,
28 public UNSUPPORT_INFO,
29 public IPDF_JSPLATFORM,
30 public FPDF_FORMFILLINFO {
Tom Sepez96d13342015-01-16 14:59:26 -080031 public:
Tom Sepez4cb0fa72015-02-25 16:08:18 -080032 class Delegate {
33 public:
Nico Weber9d8ec5a2015-08-04 13:00:21 -070034 virtual ~Delegate() {}
Tom Sepez96d13342015-01-16 14:59:26 -080035
Tom Sepez4cb0fa72015-02-25 16:08:18 -080036 // Equivalent to UNSUPPORT_INFO::FSDK_UnSupport_Handler().
Nico Weber9d8ec5a2015-08-04 13:00:21 -070037 virtual void UnsupportedHandler(int type) {}
Tom Sepez4cb0fa72015-02-25 16:08:18 -080038
39 // Equivalent to IPDF_JSPLATFORM::app_alert().
Nico Weber9d8ec5a2015-08-04 13:00:21 -070040 virtual int Alert(FPDF_WIDESTRING message,
41 FPDF_WIDESTRING title,
42 int type,
43 int icon) {
Tom Sepez4cb0fa72015-02-25 16:08:18 -080044 return 0;
45 }
Tom Sepez6efc0ad2015-06-02 17:11:18 -070046
47 // Equivalent to FPDF_FORMFILLINFO::FFI_SetTimer().
48 virtual int SetTimer(int msecs, TimerCallback fn) { return 0; }
49
50 // Equivalent to FPDF_FORMFILLINFO::FFI_KillTimer().
Nico Weber9d8ec5a2015-08-04 13:00:21 -070051 virtual void KillTimer(int id) {}
Tom Sepez396e8722015-09-09 10:16:08 -070052
53 // Equivalent to FPDF_FORMFILLINFO::FFI_GetPage().
weili0dadcc62016-08-23 21:10:57 -070054 virtual FPDF_PAGE GetPage(FPDF_FORMFILLINFO* info,
Tom Sepez396e8722015-09-09 10:16:08 -070055 FPDF_DOCUMENT document,
56 int page_index);
Tom Sepez4cb0fa72015-02-25 16:08:18 -080057 };
58
59 EmbedderTest();
60 virtual ~EmbedderTest();
Tom Sepez96d13342015-01-16 14:59:26 -080061
62 void SetUp() override;
63 void TearDown() override;
64
Tom Sepez452b4f32015-10-13 09:27:27 -070065#ifdef PDF_ENABLE_V8
Tom Sepeza72e8e22015-10-07 10:17:53 -070066 // Call before SetUp to pass shared isolate, otherwise PDFium creates one.
Tom Sepez452b4f32015-10-13 09:27:27 -070067 void SetExternalIsolate(void* isolate) {
68 external_isolate_ = static_cast<v8::Isolate*>(isolate);
69 }
70#endif // PDF_ENABLE_V8
Tom Sepeza72e8e22015-10-07 10:17:53 -070071
Tom Sepez4cb0fa72015-02-25 16:08:18 -080072 void SetDelegate(Delegate* delegate) {
Tom Sepeza72e8e22015-10-07 10:17:53 -070073 delegate_ = delegate ? delegate : default_delegate_.get();
Tom Sepez4cb0fa72015-02-25 16:08:18 -080074 }
75
Tom Sepez96d13342015-01-16 14:59:26 -080076 FPDF_DOCUMENT document() { return document_; }
Tom Sepezda8189e2015-01-30 14:41:50 -080077 FPDF_FORMHANDLE form_handle() { return form_handle_; }
Tom Sepez96d13342015-01-16 14:59:26 -080078
Tom Sepezd483eb42016-01-06 10:03:59 -080079 // Create an empty document, and its form fill environment. Returns true
80 // on success or false on failure.
81 virtual bool CreateEmptyDocument();
82
Tom Sepezda8189e2015-01-30 14:41:50 -080083 // Open the document specified by |filename|, and create its form fill
84 // environment, or return false on failure.
Wei Li091f7a02015-11-09 12:09:55 -080085 // The filename is relative to the test data directory where we store all the
86 // test files.
Jun Fangdf7f3662015-11-10 18:29:18 +080087 virtual bool OpenDocument(const std::string& filename,
thestig27ddf162016-05-23 15:06:59 -070088 const char* password = nullptr,
Jun Fangdf7f3662015-11-10 18:29:18 +080089 bool must_linearize = false);
Tom Sepez96d13342015-01-16 14:59:26 -080090
Tom Sepez96d13342015-01-16 14:59:26 -080091 // Perform JavaScript actions that are to run at document open time.
Tom Sepezda8189e2015-01-30 14:41:50 -080092 virtual void DoOpenActions();
Tom Sepez96d13342015-01-16 14:59:26 -080093
94 // Determine the page numbers present in the document.
95 virtual int GetFirstPageNum();
96 virtual int GetPageCount();
97
98 // Load a specific page of the open document.
Tom Sepezda8189e2015-01-30 14:41:50 -080099 virtual FPDF_PAGE LoadPage(int page_number);
Tom Sepez96d13342015-01-16 14:59:26 -0800100
101 // Convert a loaded page into a bitmap.
Tom Sepezda8189e2015-01-30 14:41:50 -0800102 virtual FPDF_BITMAP RenderPage(FPDF_PAGE page);
Tom Sepez96d13342015-01-16 14:59:26 -0800103
Jane Liuc533f4b2017-06-19 11:13:00 -0400104 // Convert a loaded page into a bitmap with page rendering flags specified.
105 // See public/fpdfview.h for a list of page rendering flags.
106 virtual FPDF_BITMAP RenderPageWithFlags(FPDF_PAGE page, int flags);
107
Tom Sepez96d13342015-01-16 14:59:26 -0800108 // Relese the resources obtained from LoadPage(). Further use of |page|
109 // is prohibited after this call is made.
Tom Sepezda8189e2015-01-30 14:41:50 -0800110 virtual void UnloadPage(FPDF_PAGE page);
Tom Sepez96d13342015-01-16 14:59:26 -0800111
Nicolas Pena5bcd9a32017-03-22 11:04:35 -0400112 protected:
113 void SetupFormFillEnvironment();
114
Dan Sinclair957480c2017-06-13 15:21:14 -0400115 // Return the hash of |bitmap|.
116 static std::string HashBitmap(FPDF_BITMAP bitmap,
117 int expected_width,
118 int expected_height);
119
thestigbcd3e532016-11-21 13:37:28 -0800120 // Check |bitmap| to make sure it has the right dimensions and content.
121 static void CompareBitmap(FPDF_BITMAP bitmap,
122 int expected_width,
123 int expected_height,
124 const char* expected_md5sum);
125
Tom Sepez4cb0fa72015-02-25 16:08:18 -0800126 Delegate* delegate_;
Lei Zhangaa8bf7e2015-12-24 19:13:32 -0800127 std::unique_ptr<Delegate> default_delegate_;
Tom Sepez96d13342015-01-16 14:59:26 -0800128 FPDF_DOCUMENT document_;
Tom Sepezda8189e2015-01-30 14:41:50 -0800129 FPDF_FORMHANDLE form_handle_;
Tom Sepez96d13342015-01-16 14:59:26 -0800130 FPDF_AVAIL avail_;
131 FX_DOWNLOADHINTS hints_;
132 FPDF_FILEACCESS file_access_;
133 FX_FILEAVAIL file_avail_;
Tom Sepez452b4f32015-10-13 09:27:27 -0700134#ifdef PDF_ENABLE_V8
Tom Sepez6efc0ad2015-06-02 17:11:18 -0700135 v8::Platform* platform_;
Tom Sepez452b4f32015-10-13 09:27:27 -0700136#endif // PDF_ENABLE_V8
137 void* external_isolate_;
Tom Sepez96d13342015-01-16 14:59:26 -0800138 TestLoader* loader_;
139 size_t file_length_;
Tom Sepez0aa35312016-01-06 10:16:32 -0800140 std::unique_ptr<char, pdfium::FreeDeleter> file_contents_;
weili0dadcc62016-08-23 21:10:57 -0700141 std::map<int, FPDF_PAGE> page_map_;
dsinclaircb92dc72016-09-07 09:02:48 -0700142 std::map<FPDF_PAGE, int> page_reverse_map_;
Tom Sepez4cb0fa72015-02-25 16:08:18 -0800143
144 private:
145 static void UnsupportedHandlerTrampoline(UNSUPPORT_INFO*, int type);
Nico Weber9d8ec5a2015-08-04 13:00:21 -0700146 static int AlertTrampoline(IPDF_JSPLATFORM* plaform,
147 FPDF_WIDESTRING message,
148 FPDF_WIDESTRING title,
149 int type,
150 int icon);
151 static int SetTimerTrampoline(FPDF_FORMFILLINFO* info,
152 int msecs,
Tom Sepez6efc0ad2015-06-02 17:11:18 -0700153 TimerCallback fn);
154 static void KillTimerTrampoline(FPDF_FORMFILLINFO* info, int id);
Tom Sepez396e8722015-09-09 10:16:08 -0700155 static FPDF_PAGE GetPageTrampoline(FPDF_FORMFILLINFO* info,
156 FPDF_DOCUMENT document,
157 int page_index);
Tom Sepez96d13342015-01-16 14:59:26 -0800158};
159
160#endif // TESTING_EMBEDDER_TEST_H_