public function testPostCreateRequestUnalteredPostRequest() { $query = $this->_client->createUpdate(); $query->addDeleteById(1); $requestOutput = $this->_client->createRequest($query); $requestInput = clone $requestOutput; $this->_plugin->postCreateRequest($query, $requestOutput); $this->assertEquals($requestInput, $requestOutput); }
public function testCreateRequestWithOverridingPlugin() { $overrideValue = 'dummyvalue'; $query = new Solarium_Query_Select(); $observer = $this->getMock('Solarium_Plugin_Abstract', array(), array($this->_client, array())); $observer->expects($this->once())->method('preCreateRequest')->with($this->equalTo($query))->will($this->returnValue($overrideValue)); $this->_client->registerPlugin('testplugin', $observer); $request = $this->_client->createRequest($query); $this->assertEquals($overrideValue, $request); }
<?php require 'init.php'; htmlHeader(); // This example shows how to manually execute the query flow. // By doing this manually you can customize data in between any step (although a plugin might be better for this) // And you can use only a part of the flow. You could for instance use the query object and request builder, // but execute the request in your own code. // create a client instance $client = new Solarium_Client($config); // create a select query instance $query = $client->createSelect(); // manually create a request for the query $request = $client->createRequest($query); // you can now use the request object for getting an uri (ie. to use in you own code) // or you could modify the request object echo 'Request URI: ' . $request->getUri() . '<br/>'; // you can still execute the request using the client and get a 'raw' response object $response = $client->executeRequest($request); // and finally you can convert the response into a result $result = $client->createResult($query, $response); // display the total number of documents found by solr echo 'NumFound: ' . $result->getNumFound(); // show documents using the resultset iterator foreach ($result as $document) { echo '<hr/><table>'; // the documents are also iterable, to get all fields foreach ($document as $field => $value) { // this converts multivalue fields to a comma-separated string if (is_array($value)) { $value = implode(', ', $value);