User tests: Successful: Unsuccessful:
I found that with the use of base64-encoded data streams of image files it should be possible to integrate the creation of such streams and that JImageHelper is the best place to request it from. So i added two new methods - toBase64 and fromBase64. While the former method generates a ready to use base64-encoded data stream that can be used with an <img/>
element's src-attribute as well as with CSS the latter takes such a stream and writes it into an image file.
The methods can be tested the following way:
// Array of different input types and input path scenarios to show the paths are properly handled
$files = [
'http://www.example.com/images/powered_by.png',
'/abs/path/to/joomla/images/powered_by.png',
'//images/powered_by.png',
'\\images\powered_by.png',
'images\powered_by.png',
'\\abs\\path\to\joomla\images\powered_by.png',
'http://www.example.com/images/joomla_green.gif',
'/abs/path/to/joomla/images/joomla_green.gif',
'//images/joomla_green.gif',
'\\images\joomla_green.gif',
'images\joomla_green.gif',
'\\abs\\path\to\joomla\images\joomla_green.gif',
'http://www.example.com/images/joomla_logo_black.jpg',
'/abs/path/to/joomla/images/joomla_logo_black.jpg',
'//images/joomla_logo_black.jpg',
'\\images\joomla_logo_black.jpg',
'images\joomla_logo_black.jpg',
'\\abs\\path\to\joomla\images\joomla_logo_black.jpg',
'http://www.example.com/images/joomla_logo_black2.jpeg',
'/abs/path/to/joomla/images/joomla_logo_black2.jpeg',
'//images/joomla_logo_black2.jpeg',
'\\images\joomla_logo_black2.jpeg',
'images\joomla_logo_black2.jpeg',
'\\abs\\path\to\joomla\images\joomla_logo_black2.jpeg'
];
// Iterate over the files array and output every image to your browser
foreach ($files as $f)
{
echo '<img src="' . JImageHelper::toBase64($f) . '" border="0" alt="Image"/>';
}
$streams = [
'powered_by.png' => '',
'joomla_green.gif' => '',
'joomla_logo_black.jpg' => ''
];
// Iterate over the streams array and create files to the /tmp folder.
foreach ($streams as $name => $stream)
{
JImageHelper::fromBase64($stream, true, $name, '/tmp');
}
Please test and report back.
Status | Pending | ⇒ | New |
Labels |
Added:
?
|
I'm afraid i can't. I have never written any unit test so far and have no experience in that. I don't involve unit testing locally and have no testing environment to write and test my tests before providing them to the public audience.
It is furthermore problematice as one of the tests should test for the <img/>
tags creation which requires the use of the deprecated assertion assertTag()
. How to test the html output in this case?
Mabe somebody experienced can help out and write this test?
I'll try to throw something together then.
Thanks a lot, Michael!
@itbra can you translate the Exceptions to use language strings?
Example:
throw new RuntimeException(JText::_('You selected to store the image file. However, you did not specify a file name.'));
replace with
throw new RuntimeException(JText::_('JLIB_STORE_IMAGE_FAILD_NO_FILENAME'));
Than you need to add the new Language string to
https://github.com/joomla/joomla-cms/blob/staging/language/en-GB/en-GB.lib_joomla.ini
and
https://github.com/joomla/joomla-cms/blob/staging/administrator/language/en-GB/en-GB.lib_joomla.ini
as
JLIB_STORE_IMAGE_FAILD_NO_FILENAME="You selected to store the image file. However, you did not specify a file name."
Thanks
Actually, I wouldn't translate it. Most of the libraries folder code was converted to not be translated (Exception messages typically shouldn't be shown directly to the user). JImage
is handled the same way.
Err... Whoops, wrong browser window with that last comment ;-)
Status | New | ⇒ | Pending |
@zero-24
Actually i considered to add translation when i implemented these methods - as can be noted from the //TODO - add translation
annotations. However, as @jissues-bot already stated the libraries folder show many untranslated implementations which is why i wondered if that might be a rule and why i left the translation out so far.
@mbabker
Thank you very much for taking the time and writing this test class. Mabe you can comment that to clarify the situtation?
I would translate these as they will be directly displayed to non-coders in case of error
Example: "You selected to store the image file. However, you did not specify a file name."
Absolutely agree. Then this counts for the getImageFileProperties()
messages as well. So, into which core lang file and what prefix to use - JLIB_APPLICATION_ERROR
?
They should be present in both en-GB.lib_joomla.ini (admin and site)
and I would have their constants start by
JLIB_IMAGE_ERROR_ in a new section of the file starting line 416 before the JLIB_INSTALLER_ ones
But someone may think it needs another constant... :)
I think JLIB_IMAGE_ERROR_
is good as it clearly communicates its context. Anyway, i'll add them and if there will be claims about the prefix we can replace it very fast.
Done. Hope i applied all changes in the right places. Anyone who can tell me why the travis builds fail on image.php?
However, as @jissues-bot already stated the libraries folder show many untranslated implementations which is why i wondered if that might be a rule and why i left the translation out so far.
That was actually me on the wrong account. So if this class were to get pulled up to the Framework (and I think it should as the Image library exists there and these are some useful methods), the Exceptions would again be untranslated, and the time spent translating would be wasted when the CMS ever updated to use that version of the code instead of this one. That's my only real concern here.
Mhm, what do you suggest to do, Michael?
The rule of thumb is:
The question now is: Does it make sense to show this message to a user? Usually library functions aren't directly accessed by a user. They are used by an extension which provides the form (like for example the media manager may use it). But then the form processing within the extension itself does this sanity checks and will generate a (translated) message to the user.
Maybe I'm missing something but can't this go inside the JImage
class itself? In fact we are duplicating some methods here.
Well guys, please let us find a consense to get this PR finished and merged.
What do you want me to change and where do you want me to change it? I mean, if there are doubts about which class to receive which methods we should talk about it and apply the changes if they make sense.
What do you think?
I wonder why this PR isn't discussed anymore. All functionality is implemented. All suggested changes are applied. My impression was we were close to merge it into 3.4-dev. Is there something missing?
Only PLT can decide and merge Pull requests. But here also Travis fails for some reason i don't understand.
https://travis-ci.org/joomla/joomla-cms/builds/34725103
@mbabker can you have a look here?
I also wondered why it fails. The output shown when clicking the "Detail" link does even not tell me very much since i have zero experience with CI. I triple checked my code but couldn't figure if and where it may be the reason. If anybody knows more, please tell us so i can fix it soon.
In libraries/joomla/image/image.php
, the errors are coming from a missing closing parenthesis on the lines where the Exceptions were converted to use JText.
I checked the file within another editor and can confirm this issue. I updated image.php and helper.php as of several complaint by Travis. The tests are now successful.
How to proceed?
Category | ⇒ | Libraries |
Category | Libraries | ⇒ | Feature Request Libraries |
I've tried the functions, and in function fromBase64 the fullpath ended up being wrong.
As you can see, when defining fullpath there is one too many DIRECTORY_SEPERATOR in front making the path wrong.
Status | Pending | ⇒ | Information Required |
Moving to Information required
based on the last comment by @onurtemuroglu and as the PR contains merge conflicts
Hello @itbra
Thank you for your contribution.
The last comment here was on 23rd August. Can you follow up on the feedback?
If no reply is received within 4 weeks we will close this issue.
Thanks for understanding!
This PR has received new commits.
CC: @onurtemuroglu
Labels |
Added:
?
?
|
Labels |
Added:
?
?
|
Status | Information Required | ⇒ | Pending |
Labels |
Category | Libraries Feature Request | ⇒ | Feature Request Language & Strings Libraries |
Status | Pending | ⇒ | Closed |
Closed_Date | 0000-00-00 00:00:00 | ⇒ | 2016-05-08 14:29:34 |
Closed_By | ⇒ | roland-d |
Labels |
Thanks everybody for your contribution, since there is no longer a follow-up and we have an issue and merge conflicts I am going to close this issue. Feel free to open this issue again when you have time to work on it.
Can you add the test data as a unit test class? Just add a JImageHelperTest class here.