-
Notifications
You must be signed in to change notification settings - Fork 15
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
#772: Throw an error if installation of R package fails and run integ…
…ration tests for R package in standard container
- Loading branch information
Showing
5 changed files
with
113 additions
and
139 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
60 changes: 60 additions & 0 deletions
60
test_container/tests/test/standard-flavor/all/import_r_modules.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,60 @@ | ||
#!/usr/bin/env python3 | ||
from typing import List | ||
|
||
from exasol_python_test_framework import udf | ||
from exasol_python_test_framework.udf.udf_debug import UdfDebugger | ||
|
||
class ImportAllModulesTest(udf.TestCase): | ||
|
||
def setUp(self): | ||
self.query('create schema import_all_r_modules', ignore_errors=True) | ||
|
||
def get_all_root_modules(self) -> List[str]: | ||
self.query(udf.fixindent(''' | ||
CREATE OR REPLACE r SCALAR SCRIPT import_all_r_modules.get_all_root_modules() | ||
EMITS (module_name VARCHAR(200000)) AS | ||
run <- function(ctx) { | ||
library(data.table) | ||
file_pattern <- "cran_packages" | ||
directory <- "/build_info/packages" | ||
files <- list.files(path = directory, pattern = file_pattern, full.names = TRUE, recursive = TRUE) | ||
for (file in files) { | ||
package_list <- fread(file, sep="|", header = FALSE, col.names = c("Package", "Version")) | ||
package_names <- package_list[[1]] | ||
ctx$emit(package_names) | ||
} | ||
} | ||
/ | ||
''')) | ||
rows = self.query('''SELECT import_all_r_modules.get_all_root_modules() FROM dual''') | ||
print("Number of modules:",len(rows)) | ||
root_modules = [row[0] for row in rows] | ||
print(f"Found {len(root_modules)} root modules.") | ||
return root_modules | ||
|
||
def create_check_installed_package_udf(self): | ||
self.query(udf.fixindent(''' | ||
CREATE OR REPLACE r SCALAR SCRIPT | ||
import_all_r_modules.check_installed_package(package_name VARCHAR(200000)) | ||
RETURNS DECIMAL(11,0) AS | ||
run <- function(ctx) { | ||
library(ctx$package_name, character.only = TRUE) | ||
0 | ||
} | ||
/ | ||
''')) | ||
|
||
def test_import_all_modules(self): | ||
root_modules = self.get_all_root_modules() | ||
assert len(root_modules) > 0 | ||
self.create_check_installed_package_udf() | ||
for root_module in root_modules: | ||
# with UdfDebugger(test_case=self): | ||
rows = self.query(f'''SELECT import_all_r_modules.check_installed_package('{root_module}') FROM dual''') | ||
|
||
def tearDown(self): | ||
self.query("drop schema import_all_r_modules cascade", ignore_errors=True) | ||
|
||
|
||
if __name__ == '__main__': | ||
udf.main() |