Infolog - fix bugs with contact & project ID fighting

This commit is contained in:
nathangray 2017-09-15 11:24:06 -06:00
parent 9563049f41
commit 5e36e2f033
4 changed files with 85 additions and 11 deletions

View File

@ -460,6 +460,11 @@ class infolog_bo
{ {
$info['old_pm_id'] = $info['pm_id'] = $id; $info['old_pm_id'] = $info['pm_id'] = $id;
} }
else
{
// Link might be contact, check others
$this->get_pm_id($info);
}
$info['info_link'] = $info['info_contact'] = array( $info['info_link'] = $info['info_contact'] = array(
'app' => $app, 'app' => $app,
'id' => $id, 'id' => $id,
@ -469,13 +474,28 @@ class infolog_bo
//echo " title='$title'</p>\n"; //echo " title='$title'</p>\n";
return $info['blur_title'] = $title; return $info['blur_title'] = $title;
} }
$info['info_link'] = $info['info_contact'] = array('id' => 'none', 'title' => $info['info_from']);
// Set ID to 'none' instead of unset to make it seem like there's a value
$info['info_link'] = $info['info_contact'] = $info['info_from'] ? array('id' => 'none', 'title' => $info['info_from']) : null;
$info['info_link_id'] = 0; // link might have been deleted $info['info_link_id'] = 0; // link might have been deleted
$info['info_custom_from'] = (int)!!$info['info_from']; $info['info_custom_from'] = (int)!!$info['info_from'];
return False; return False;
} }
/**
* Find projectmanager ID from linked project(s)
*
* @param Array $info
*/
public function get_pm_id(&$info)
{
$pm_links = Link::get_links('infolog',$info['info_id'],'projectmanager');
$old_pm_id = is_array($pm_links) ? array_shift($pm_links) : $info['old_pm_id'];
if (!isset($info['pm_id']) && $old_pm_id) $info['pm_id'] = $old_pm_id;
}
/** /**
* Create a subject from a description: truncate it and add ' ...' * Create a subject from a description: truncate it and add ' ...'
*/ */
@ -1051,7 +1071,12 @@ class infolog_bo
protected function write_check_links(&$values) protected function write_check_links(&$values)
{ {
$old_link_id = (int)$values['info_link_id']; $old_link_id = (int)$values['info_link_id'];
if($values['info_contact']) if($values['info_contact'] && !(
is_array($values['info_contact']) && $values['info_contact']['id'] == 'none'
) || (
is_array($values['info_contact']) && $values['info_contact']['id'] == 'none' &&
array_key_exists('search', $values['info_contact'])
))
{ {
if(is_array($values['info_contact'])) if(is_array($values['info_contact']))
{ {
@ -1106,6 +1131,19 @@ class infolog_bo
else else
{ {
unset($values['info_link_id']); unset($values['info_link_id']);
$values['info_from'] = null;
}
if($values['info_id'] && $values['old_pm_id'] !== $values['pm_id'])
{
// Project has changed, but link is not to project
if($values['pm_id'])
{
$link_id = Link::link('infolog', $values['info_id'], 'projectmanager', $values['pm_id']);
if(!$values['info_link_id'])
{
$values['info_link_id'] = $link_id;
}
}
} }
if ($old_link_id && $old_link_id != $values['info_link_id']) if ($old_link_id && $old_link_id != $values['info_link_id'])
{ {

View File

@ -2347,7 +2347,7 @@ class infolog_ui
if (!isset($content['info_contact']) || empty($content['info_contact']) || $content['info_contact'] === 'copy:') if (!isset($content['info_contact']) || empty($content['info_contact']) || $content['info_contact'] === 'copy:')
{ {
$linkinfos = Link::get_link($info_link_id); $linkinfos = Link::get_link($info_link_id);
$content['info_contact'] = $linkinfos['link_app1']=='infolog'? $content['info_contact'] = $linkinfos['link_app1']=='infolog'?
array('app' => $linkinfos['link_app2'], 'id' => $linkinfos['link_id2']): array('app' => $linkinfos['link_app2'], 'id' => $linkinfos['link_id2']):
array('app' => $linkinfos['link_app1'], 'id' => $linkinfos['link_id1']); array('app' => $linkinfos['link_app1'], 'id' => $linkinfos['link_id1']);
if ($content['info_contact']['app'] == 'projectmanager') if ($content['info_contact']['app'] == 'projectmanager')

View File

@ -63,15 +63,15 @@ class ContactTest extends \EGroupware\Api\AppTest
'search'=> 'Free text' 'search'=> 'Free text'
) )
); );
$info = $this->getTestInfolog($content); $info = $this->getTestInfolog($content);
// Skipping notifications - save initial state // Skipping notifications - save initial state
$this->info_id = $this->bo->write($info, true, true, true, true); $this->info_id = $this->bo->write($info, true, true, true, true);
// Read it back to check // Read it back to check
$saved = $this->bo->read($this->info_id); $saved = $this->bo->read($this->info_id);
$this->assertEquals($content['contact']['search'], $saved['info_from']); $this->assertEquals($content['contact']['search'], $saved['info_from']);
$this->assertEquals(0, $saved['info_link_id']); $this->assertEquals(0, $saved['info_link_id']);

View File

@ -190,12 +190,48 @@ class SetProjectManagerTest extends \EGroupware\Api\AppTest
$this->checkElements(); $this->checkElements();
} }
/**
* Test free text in the contact field
*/
public function testFreeContact()
{
$info = $this->getTestInfolog();
// Set up the test - just set info_contact
$info['info_contact'] = array(
'app' => null,
'id' => null,
'search' => 'Free text'
);
// Set project by pm_id
$info['pm_id'] = $this->pm_id;
$this->info_id = $this->bo->write($info);
$this->assertArrayHasKey('info_id', $info, 'Could not make test infolog');
$this->assertThat($this->info_id,
$this->logicalAnd(
$this->isType('integer'),
$this->greaterThan(0)
)
);
// Check infolog has pm_id properly set
$this->assertEquals($this->pm_id, $info['pm_id']);
// Force links to run notification now so we get valid testing - it
// usually waits until Egw::on_shutdown();
Api\Link::run_notifies();
// Check project
$this->checkElements();
}
public function testLoadWithProject() public function testLoadWithProject()
{ {
// Saving the infolog should try to send a notification // Saving the infolog should try to send a notification
$this->bo->tracking->expects($this->once()) $this->bo->tracking->expects($this->once())
->method('track') ->method('track')
->with($this->callback(function($subject) { return $subject['pm_id'] == $this->pm_id;})); ->will($this->returnCallback(function($subject) { return $subject['pm_id'] == $this->pm_id;}));
$info = $this->getTestInfolog(); $info = $this->getTestInfolog();
@ -209,7 +245,7 @@ class SetProjectManagerTest extends \EGroupware\Api\AppTest
$this->greaterThan(0) $this->greaterThan(0)
) )
); );
// Check infolog has pm_id properly set // Check infolog has pm_id properly set
$this->assertEquals($this->pm_id, $info['pm_id']); $this->assertEquals($this->pm_id, $info['pm_id']);
@ -268,7 +304,7 @@ class SetProjectManagerTest extends \EGroupware\Api\AppTest
// Check pm_id is gone // Check pm_id is gone
$this->assertNull($info['pm_id'], 'Project was not removed'); $this->assertNull($info['pm_id'], 'Project was not removed');
// Force links to run notification now so we get valid testing - it // Force links to run notification now so we get valid testing - it
// usually waits until Egw::on_shutdown(); // usually waits until Egw::on_shutdown();
Api\Link::run_notifies(); Api\Link::run_notifies();
@ -322,7 +358,7 @@ class SetProjectManagerTest extends \EGroupware\Api\AppTest
// Check contact was cleared // Check contact was cleared
$this->assertNull($info['info_contact'], 'Contact was not cleared'); $this->assertNull($info['info_contact'], 'Contact was not cleared');
// Check pm_id is gone // Check pm_id is gone
$this->assertNull($info['pm_id'], 'Project was not removed'); $this->assertNull($info['pm_id'], 'Project was not removed');
@ -393,7 +429,7 @@ class SetProjectManagerTest extends \EGroupware\Api\AppTest
$this->assertEquals($expected_count, $element_count, "Incorrect number of elements"); $this->assertEquals($expected_count, $element_count, "Incorrect number of elements");
} }
/** /**
* Fully delete a project and its elements, no matter what state or settings * Fully delete a project and its elements, no matter what state or settings
*/ */